/*所谓的质因子的分解是将一个正整数 n 写成一个或多个质数的乘积
如果一个质数的出现次数较多 那就可以用指数的方法输出
方法:
先打印出质数表 并注意判断质数表的大小差不多为多少
注意 1是没有质因子的 要单独列出来写
*/
//每一个质因子可能出现不止一次 用结构体表示
struct fac{
int x, cnt;
};
//因为n 可以分解为2个数的 积 那必定一个在sqr(n) 的左边 一个在右半部分
// 如果右半部分可以被分解的话 那可能右边的就没有了 只有左边
//所以 在sqr(n)右边的 最多只有一个
枚举1-sqr(n) 以内的所有的质因子 看是不是n的因子
代码如下
if( n %prime(i) == 0){
fac[num].x=prime(i);
fac[num].cnt=0;
while(n % prime[i] ==0){
fac[num].cnt++;
n /= prime[i];
}
num++;
}
if( n! = 1){
fac[num].x = n;
fac[num++].cnt=1;
}
if(n == 1) break;
#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
pat 甲级 1059题解
bool isprime(int n){
if(n <=1) return false;
int sqr =(int) sqrt(1.0 * n) ;
for(int i=2; i<=sqr; i++){
if( n% i ==0) return false;
}
return true;
}
const int maxn=100010;
int prime[maxn] ,pnum=0;
void find(){
for(int i=1;i<maxn;i++){
if(isprime(i) == true){
prime[pnum++]=i;
}
}
}
struct factor{
int x,cnt;
}fac[10];
int main()
{
find();
int n,num=0;
cin>>n;
if(n == 1) cout<<"1=1";
else{
cout<<n<<=;
int sqr=(int) sqrt(1.0*n);
for(int i=0;i<pnum && prime[i] <=sqr;i++){
if(n %prime[i] == 0){
fac[num].x=i;
fac[num].cnt=0;
while( n % prime[i] == 0){
fac[num].cnt++;
n/=prime[i];
}
num++;
}
if(n == 1) break;
}
if(n != 1) {
fac[num].x =n;
fac[num++].cnt =1;
}
for( int i=0;i<num;i++){
if(i>0 ) cout<<"*";
cout<<fac[i].x;
if(fac[i].cnt >1 ){
cout<<"^"<<fac[i].cnt;
}
}
}
return 0;
}