质因数分解 (主要怕忘记 发一个博客)

/*所谓的质因子的分解是将一个正整数 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 
#include 
#include 
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;
}
    


你可能感兴趣的:(算法)