首页 > 其他 > 详细

N!的素因子分解

时间:2014-12-16 19:17:39      阅读:331      评论:0      收藏:0      [点我收藏+]

N! = p1^t1*p2^t2*pi^ti*pk^tk(其中p1p2……pk是素数,1<N<= 10^6

很明显我们首先要筛出小于等于n的所有素数

然后我们将n分成两部分考虑,

1)为某个素因子的倍数,2)不是这个因子的倍数

例如: f(n,2) 

n!=(2*4*6*....n)*(1*3*5*.....*(n-1)) 

   =2^(n/2)*(1*2*3*4*......n/2)*(1*3*5*..(n-1))  得到了

   ......

   因此我们就得到了递推公式 对某个因子的次数 f(n,p) = f(n/p,p)+ n/p ;


下面这个还讲了关于这个问题的推广

http://www.cnblogs.com/openorz/archive/2011/11/14/2248992.html


代码如下:

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;

const int maxn = 10000010;
int prime[maxn],cnt;
int ans[maxn];
bool is[maxn];

void init(int n)
{
    cnt=0;
    memset(is,1,sizeof(is));
    memset(ans,0,sizeof(ans));
    memset(prime,0,sizeof(prime));
    for(int i=2;i<=n;i++){
        if(is[i]){
            prime[cnt++]=i;
            for(int j=i+i;j<=n;j+=i)
                is[j]=0;
        }
    }
}

int fen(int n,int p)
{
    if(n==0) return 0;
    return fen(n/p,p)+n/p;
}
int main()
{
    int n;
    while(~scanf("%d",&n)){
        init(n);
        for(int i=0;i<cnt;i++)
            ans[i]=fen(n,prime[i]);
        for(int i=0;i<cnt;i++)
            printf("%d^%d\n",prime[i],ans[i]);
    }
    return 0;
}


N!的素因子分解

原文:http://blog.csdn.net/bigbigship/article/details/41963023

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!