【每日一题】—— D. Divide and Equalize(Codeforces Round 903 (Div. 3))(数学、数论)

🌏博客主页:PH_modest的博客主页

🚩当前专栏:每日一题

💌其他专栏:

🔴 每日反刍

🟡 C++跬步积累

🟢 C语言跬步积累

🌈座右铭:广积粮,缓称王!

一.题目描述

题目大意:

给你一个由 n n n 个正整数组成的数组 a a a 。你可以对它进行以下操作:

  1. 选择一对元素 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 );
  2. 选择整数 a i a_i ai 的除数之一,即整数 x x x ,使得 a i   m o d   x = 0 a_i \bmod x = 0 aimodx=0 ;
  3. 用 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 个元素。对它进行两次运算:
  4. 选择 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 ];
  5. 选择 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))

二.思路分析

  1. 题目的意思就是将一个数的因子给另一个数,使得最后数字要相同
  2. 也就是说最后每个数的因子都是一样的
  3. 所以只需要分解每个数,最后判断一下每个因子的个数是不是n的倍数就可以了

三.代码展示

cpp 复制代码
//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上的题目,想要学习算法的友友们千万别错过了,有什么疑问欢迎大家在评论区留言或者私信博主!
在这里送大家一句话:广积粮,缓称王!

相关推荐
别NULL4 分钟前
机试题——最小矩阵宽度
c++·算法·矩阵
珊瑚里的鱼5 分钟前
【单链表算法实战】解锁数据结构核心谜题——环形链表
数据结构·学习·程序人生·算法·leetcode·链表·visual studio
林涧泣6 分钟前
图的矩阵表示
学习·线性代数·矩阵
无限码力9 分钟前
[矩阵扩散]
数据结构·算法·华为od·笔试真题·华为od e卷真题
gentle_ice9 分钟前
leetcode——矩阵置零(java)
java·算法·leetcode·矩阵
查理零世11 分钟前
保姆级讲解 python之zip()方法实现矩阵行列转置
python·算法·矩阵
chimchim6613 分钟前
【starrocks学习】之catalog
学习
zhbi9831 分钟前
测量校准原理
算法
时间很奇妙!1 小时前
decison tree 决策树
算法·决策树·机器学习
Icomi_1 小时前
【外文原版书阅读】《机器学习前置知识》1.线性代数的重要性,初识向量以及向量加法
c语言·c++·人工智能·深度学习·神经网络·机器学习·计算机视觉