数论整理之唯一质因子分解方程

简介: 数论整理之唯一质因子分解方程

唯一质因子分解方程

每个大于1的自然数均可写为质数的积,而且这些素因子按大小排列之后,写法仅有一种方式。

标称:

#include <iostream>
#include <cstring>
#include <cstdlib>
using namespace std;
const int MAXN = 65540;
int a[MAXN];
int main(){
    int n;
    while(cin >> n && n){
        int cnt = 0;
        for(int i=2;i<=n;++i){
            while(n % i == 0){
                a[cnt++] = i;
                n /= i;
            }
        }
        for(int i=0;i<cnt-1;++i){
            cout << a[i] << "*";
        }
        cout << a[cnt-1] << endl;
    }
    return 0;
}

one 试除法:无论素数判定还是因子分解,试除法(Trial Division)都是首先要进行的步骤。令m=n,从2~根n一一枚举,如果当前数能够整除m,那么当前数就是n的素数因子,并用整数m

将当前数除尽为止。

若循环结束后m是大于1的整数,那么此时m也是n的素数因子

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <math.h>
#define N 65535
using namespace std;
int factor[N],top;
void divide(int n)
{
    for(int i=2; i<=sqrt(n+0.0); i++)
    {
        while(n%i==0)
        {
            top++;
            factor[top]=i;
            n/=i;
        }
    }
    if(n!=1)
    {
        top++;
        factor[top]=n;
    }
    for(int i=1; i<=top-1; i++)
    {
        printf("%d*",factor[i]);
    }
    printf("%d\n",factor[top]);
    return ;
}
int main()
{
    int n;
    while(scanf("%d",&n)!=EOF)
    {
        top=0;
        divide(n);
    }
    return 0;
}

two:在试除法基础上加上筛法(埃氏筛),减少时间

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <math.h>
#define N 65540
using namespace std;
int factor[N],top,cnt,prime[N];
bool b[N];
void make_prime()
{
    top=0;
    b[0]=b[1]=false;
    b[2]=true;
    prime[++top]=2;
    for(int i=3; i<N; i++)
        if(i%2==0) b[i]=false;
        else b[i]=true;
    double t=sqrt(1000000*1.0);
    for(int i=3; i<=t; i++)
    {
        if(b[i])
        {
            prime[++top]=i;
            for(int j=i*i; j<N; j=j+i)
            {
                b[j]=false;
            }
        }
    }
}
void divide(int n)
{
    cnt=0;
    int temp=sqrt(n+0.0);
    for(int i=1; i<=top; i++)
    {
        if(prime[i]>temp)
            break;
        while(n%prime[i]==0)
        {
            cnt++;
            factor[cnt]=prime[i];
            n/=prime[i];
        }
    }
    if(n!=1)
    {
        cnt++;
        factor[cnt]=n;
    }
    for(int i=1; i<=cnt-1; i++)
    {
        printf("%d*",factor[i]);
    }
    printf("%d\n",factor[cnt]);
    return ;
}
int main()
{
    int n;
    make_prime();
    while(scanf("%d",&n)!=EOF)
    {
        divide(n);
    }
    return 0;
}
相关文章
|
6月前
线性代数——(期末突击)概率统计习题(概率的性质、全概率公式)
线性代数——(期末突击)概率统计习题(概率的性质、全概率公式)
58 1
|
机器学习/深度学习
数论整理之欧拉函数
数论整理之欧拉函数
148 0
|
算法 C++
算法基础系列第四章——数论之从欧拉卷到欧几里得(1)
算法基础系列第四章——数论之从欧拉卷到欧几里得(1)
166 0
算法基础系列第四章——数论之从欧拉卷到欧几里得(1)
|
算法 C++
算法基础系列第四章——数论之从欧拉卷到欧几里得(2)
算法基础系列第四章——数论之从欧拉卷到欧几里得(2)
100 0
算法基础系列第四章——数论之从欧拉卷到欧几里得(2)
|
存储 算法 图计算
数学知识:容斥原理
复习acwing算法基础课的内容,本篇为讲解数学知识:容斥原理,关于时间复杂度:目前博主不太会计算,先鸽了,日后一定补上。
158 0
数学知识:容斥原理
|
机器学习/深度学习
数论部分第二节:埃拉托斯特尼筛法
埃拉托斯特尼筛法 质数又称素数。指在一个大于1的自然数中,除了1和此整数自身外,没法被其他自然数整除的数。怎么判断n以内的哪些数是质数呢? 埃拉托斯特尼筛法 厄拉多塞是一位古希腊数学家,他在寻找素数时,采用了一种与众不同的方法:先将2-N的各数放入表中,然后在2的上面画一个圆圈,然后划去2的其他倍数;第一个既未画圈又没有被划去的数是3,将它画圈,再划去3的其他倍数;现在既未画圈又没有被划去的第一个数是5,将它画圈,并划去5的其他倍数……依次类推,一直到所有小于或等于N的各数都画了圈或划去为止。
1091 0

热门文章

最新文章