1008 N的阶乘 mod P ——51Nod(同余定理)

基准时间限制:1 秒 空间限制:131072 KB

输入N和P(P为质数),求N! Mod P = ? (Mod 就是求模 %)

例如:n = 10, P = 11,10! = 3628800
3628800 % 11 = 10

Input
两个数N,P,中间用空格隔开。(N < 10000, P < 10^9)

Output
输出N! mod P的结果。

Input示例
10 11
Output示例
10

思路:(a+b)%m=(a%m+b%m)%m
(a*b)%m=(a%m*b%m)%m

代码:

#include <cstdio>
#include <iostream>

using namespace std; 

int main()  
{  
    long long n,p;  
    cin>>n>>p;   
    if(!n)  
    {  
        cout<<1%p;   
    }   
    else  
    {  
        long long sum=1;  
        for(long long i=2 ; i<=n ; i++)  
        {  
            sum = sum%p * i%p;   
        }  
        cout<<sum%p<<endl;   
    }   

    return 0;   
}   
posted @ 2017-10-14 13:26  Assassin_poi君  阅读(356)  评论(0编辑  收藏  举报