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

相关推荐
其实防守也摸鱼12 小时前
dirsearch安装与配置:新手入门指南
网络·数据库·学习·学习方法·目录扫描·虚拟机工具
liuyao_xianhui12 小时前
map和set_C++
java·开发语言·数据结构·c++·算法·宽度优先
念恒1230612 小时前
Linux基础开发工具(git篇)
linux·c语言·git
香蕉鼠片12 小时前
八股C++
开发语言·c++
feng_you_ying_li12 小时前
C++之智能指针的介绍与实现
c++
墨^O^12 小时前
C++ Memory Order 完全指南:从 relaxed 到 seq_cst,深入理解无锁编程与 happens-before
linux·开发语言·c++·笔记·学习·算法·缓存
阿荻在肝了12 小时前
Agent学习五:LangGraph学习-节点与可控性
人工智能·python·学习·agent
玄米乌龙茶12313 小时前
Web Search API 实操:构建智能搜索 Agent
人工智能·笔记·学习
Hical_W13 小时前
深入学习CPP20_协程
学习·github
星幻元宇VR13 小时前
VR党建互动平台助力党建学习提质增效
科技·学习·安全·vr·虚拟现实