关闭

NYOJ 70-阶乘因式分解(二)

标签: 数学因式分解
579人阅读 评论(0) 收藏 举报
分类:

题目地址:NYOJ 70

思路:n!=(1*2*3*4*......*(n-1)*n)=(m*2m*3m*.....*(k-1)m*km)*其他=(1*2*3*....*k)*m*其它 。其中km是最大值,km<=n所以k的最大值是n/m,所以[1,n]中有n/m个数能被n整除,

然后[1,n]中每个数除以m,就剩了[1,n/m],然后继续根据上面的步骤进行运算,一直到n=0的时候结束,所得的结果和为最终的结果.

#include <stdio.h>
#include <math.h>
#include <string.h>
#include <stdlib.h>
#include <iostream>
#include <sstream>
#include <algorithm>
#include <set>
#include <queue>
#include <stack>
#include <map>
using namespace std;
typedef long long LL;
const int inf=0x3f3f3f3f;
const double pi= acos(-1.0);
const double esp=1e-6;
int main()
{
    int T,n,m,i;
    LL sum;
    scanf("%d",&T);
    while(T--){
        scanf("%d %d",&n,&m);
        sum=0;
        while(n){
            sum+=n/m;
            n=n/m;
        }
        printf("%d\n",sum);
    }
    return 0;
}



1
1

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:284950次
    • 积分:7870
    • 等级:
    • 排名:第2608名
    • 原创:496篇
    • 转载:11篇
    • 译文:0篇
    • 评论:47条
    最新评论