同一时候为了追求有后宫的素养的生活,喵喵每天都要研究
质数。
我们先来复习一下什么叫做组合数。对于正整数P、T  
          
                                             
然后我们再来复习一下什么叫质数。质数就是素数,假设说正整数N的约数仅仅有1和它本身,N就是质数;另外。
1不是质数。
今天,喵喵想要知道
                                 
Input
输入第一行是一个整数N(N<=1000)。
接下来N行,每行包含一个正整数T和一个质数P(1<=P<=T<231)。
Output
包含N行,依据输入的顺序。每一行为一个整数:
Sample Input
2
3 2
10 3
Sample Output
1
0
HINT
Source
CPC3
解题思路:
这题是纯数学题,唉,数学就是硬伤啊!
搞了半天。没有结果。果断百度了一下,结果搜到了不明觉历的Lucas定理,据说是专门解决C(n, m)%p的,当中p是质数。
Lucas定理叙述例如以下:
,所以。n = p, 代入得 Lucas(n,m,p)  =   cm(n%p, m%p)* Lucas(n/p,
 m/p, p)#include <iostream>
#include <cstdio>
using namespace std;
int main(){
	freopen("in.txt", "r", stdin);
	int n, t, p;
	cin >> n;
	while(n--){
		cin >> t >> p;
		cout << (t / p) % p << endl;
 	}
 	return 0;
}原文:http://www.cnblogs.com/yxysuanfa/p/7246904.html