CCF-CSP 32-2 因子化简(prime)【C++】考点:素数因子分解(试除法)

题目

TUOJhttps://sim.csp.thusaac.com/contest/32/problem/1

思路参考:202312(第32次)CCF CSP真题202312-1,2讲解_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1J5411z7bV?vd_source=5366be93f43e6a40161aecaec29f4a2a&spm_id_from=333.788.videopod.sections

思路

核心思路:用map<int,int>mp存储每个因子的幂次,从因子p=2开始,如果能整除就除p,需要注意的是通过这种试除法得到的自然都是素数因子

代码

可以让AI总结一下代码逻辑

  1. 输入处理:读取查询次数 q。对于每组数据,输入待化简的数 n 和阈值 k。
  2. 质因数分解 :通过从 2 开始递增的整数 p 尝试整除 n,统计 n 的每个质因子及其出现的次数(幂次),并存储在 map<ll, int> mp 中。
  3. 筛选与累乘 :遍历 map 中的质因子。如果某个质因子的出现次数 t.second≥k,则计算其幂次项 p^c 并累乘到 ans 中。
  4. 输出结果 :输出最终的累乘积 ans
cpp 复制代码
/*
因子分解 
*/
#include<bits/stdc++.h>
using namespace std;
#define endl '\n'
#define ll long long
map<ll,int>mp;

void solve(){
	int q; cin>>q;
	while(q--){
		mp.clear();//WARN:全局数组记得每组数据都清空,不然就弄成局部的 
		ll n; int k; cin>>n>>k;
		int p=2; //因子
		while(n!=1){
			if(n%p==0){
				mp[p]++;
				n/=p; 
			}
			else p++;
		} 
		ll ans=1;
		for(auto t:mp)
			if(t.second>=k) ans*=pow(t.first,t.second); //warn:乘上该因子的幂次 
		cout<<ans<<endl;
	}
} 

int main(){
	ios::sync_with_stdio(0),cin.tie(0);
	solve();
	return 0;
}
相关推荐
Crazyong1 分钟前
FreeRTOS-互斥量-2
算法
落日漫游3 分钟前
Zabbix监控实战:Linux主机全流程配置
运维·开发语言·自动化
带娃的IT创业者4 分钟前
Python 异步编程完全指南(二):深入 asyncio 核心概念
开发语言·python·协程·事件循环·asyncio·异步编程
CAACoder4 分钟前
CATIA/3DE CAA二次开发-ScrollWindow滚动窗口
开发语言·c++·mfc·滚动窗口
还是大剑师兰特4 分钟前
Vue3 页面权限控制实战示例(路由守卫 + 权限判断)
开发语言·前端·javascript
ht巷子6 分钟前
asio::ip::tcp学习
网络·c++·tcp/ip
老前端的功夫8 分钟前
【Java从入门到入土】06:String的72变:从字符串拼接到底层优化
java·开发语言
啊我不会诶9 分钟前
2025 北京市大学生程序设计竞赛暨“小米杯”全国邀请赛
c++·学习·算法
程序猿(雷霆之王)10 分钟前
C++——AI大模型接入SDK
开发语言·c++
mit6.82411 分钟前
懒更新|单点查询
算法