B3871 题解

发布时间 2023-11-15 21:00:00作者: ZnHF

题目链接

题意简述

给定一个正整数 \(N\),将它的因数分解式按规定输出。

题目分析

模拟题意即可。

具体地,我们可以枚举 \(2\)\(\lfloor \sqrt N \rfloor\) 中所有数 \(i\),如果 \(i\) 能整除 \(N\),则不断地从 \(N\) 中除掉 \(i\),直到 \(i\) 不再能整除 \(N\),在这个过程中,我们同时需要统计被除掉的每个 \(i\) 的个数。

注意,本题中 \(N\) 的规模为 \(2 \le N \le 10^{12}\),需要开 long long

Code

#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,m,p[1000005],c[1000005];
signed main(){
	cin>>n;
	int N=n;
	for(int i=2;i<=sqrt(N);i++){
		if(!(n%i)){
			p[++m]=i;
			c[m]=0;
			while(!(n%i)){
				n/=i;
				c[m]++;
			}
		}
	}
	if(n>1){
		p[++m]=n;
		c[m]=1;
	}
	for(int i=1;i<=m;i++){
		if(i==m){
			if(c[i]==1){
				cout<<p[i];
			}
			else{
				cout<<p[i]<<"^"<<c[i];
			}	
			continue;		
		}
		if(c[i]==1){
			cout<<p[i]<<" * ";
		}
		else{
			cout<<p[i]<<"^"<<c[i]<<" * ";
		}
	}
	return 0;
}