【每日一题】—— D. Divide and Equalize(Codeforces Round 903 (Div. 3))(数学、数论)
2023-12-14 23:30:46
🌏博客主页:PH_modest的博客主页
🚩当前专栏:每日一题
💌其他专栏:
🔴 每日反刍
🟡 C++跬步积累
🟢 C语言跬步积累
🌈座右铭:广积粮,缓称王!
一.题目描述
题目大意:
给你一个由 n n n 个正整数组成的数组 a a a 。你可以对它进行以下操作:
- 选择一对元素 a i a_i ai? 和 a j a_j aj? ( 1 ≤ i , j ≤ n 1 \le i, j \le n 1≤i,j≤n 和 i ≠ j i \neq j i=j );
- 选择整数 a i a_i ai? 的除数之一,即整数 x x x ,使得 a i ? m o d ? x = 0 a_i \bmod x = 0 ai?modx=0 ;
- 用 a i x \frac{a_i}{x} xai?? 代替 a i a_i ai? ,用 a j ? x a_j \cdot x aj??x 代替 a j a_j aj? 。
判断是否有可能通过一定次数(可能为零)的运算使数组中的所有元素都相同。
例如,数组 a a a = [ 100 , 2 , 50 , 10 , 1 100, 2, 50, 10, 1 100,2,50,10,1 /]包含 5 5 5 个元素。对它进行两次运算:- 选择 a 3 = 50 a_3 = 50 a3?=50 和 a 2 = 2 a_2 = 2 a2?=2 , x = 5 x = 5 x=5 .用 a 3 x = 50 5 = 10 \frac{a_3}{x} = \frac{50}{5} = 10 xa3??=550?=10 替换 a 3 a_3 a3? ,用 a 2 ? x = 2 ? 5 = 10 a_2 \cdot x = 2 \cdot 5 = 10 a2??x=2?5=10 替换 a 2 a_2 a2? 。得到的数组是 a a a = [ 100 , 10 , 10 , 10 , 1 100, 10, 10, 10, 1 100,10,10,10,1 ];
- 选择 a 1 = 100 a_1 = 100 a1?=100 和 a 5 = 1 a_5 = 1 a5?=1 , x = 10 x = 10 x=10 .用 a 1 x = 100 10 = 10 \frac{a_1}{x} = \frac{100}{10} = 10 xa1??=10100?=10 替换 a 1 a_1 a1? ,用 a 5 ? x = 1 ? 10 = 10 a_5 \cdot x = 1 \cdot 10 = 10 a5??x=1?10=10 替换 a 5 a_5 a5? 。得到的数组是 a a a = [ 10 , 10 , 10 , 10 , 10 10, 10, 10, 10, 10 10,10,10,10,10 ]。
进行这些运算之后,数组 a a a 中的所有元素都等于 10 10 10 。
题目链接:
D. Divide and Equalize(Codeforces Round 903 (Div. 3))
二.思路分析
- 题目的意思就是将一个数的因子给另一个数,使得最后数字要相同
- 也就是说最后每个数的因子都是一样的
- 所以只需要分解每个数,最后判断一下每个因子的个数是不是n的倍数就可以了
三.代码展示
//https://codeforces.com/contest/1881/problem/D
//分解所有的数,如果最后所有因子都是n的倍数,那就是yes
//
#include<iostream>
#include<algorithm>
#include<string>
#include<map>
#include<queue>
#include<vector>
#include<cstring>
#define int long long
using namespace std;
void solve()
{
map<int,int>mp;
int n;
cin>>n;
for(int i=0;i<n;i++)
{
int a;
cin>>a;
for(int j=2;j*j<=a;j++)
{
while(a%j==0)
{
mp[j]++;
a/=j;
}
}
mp[a]++;
}
for(auto x:mp)
{
if(x.first<=1)
{
continue;
}
if(x.second%n!=0)
{
cout<<"NO"<<"\n";
return;
}
}
cout<<"Yes"<<"\n";
}
signed main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int t;
cin>>t;
while(t--)
{
solve();
}
return 0;
}
最后:
每日一题系列旨在养成刷题的习惯,所以对代码的解释并不会特别详细,但足够引导大家写出来,选的题目都不会特别难,但也不是特别简单,比较考验大家的基础和应用能力,我希望能够将这个系列一直写下去,也希望大家能够和我一起坚持每天写代码。
之后每个星期都会不定期更新codeforces和atcoder上的题目,想要学习算法的友友们千万别错过了,有什么疑问欢迎大家在评论区留言或者私信博主!
在这里送大家一句话:广积粮,缓称王!
文章来源:https://blog.csdn.net/PH_modest/article/details/134866107
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!