使用C(n,k)与C(n,k-1)的递推关系来求组合数。
代码如下:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <algorithm>
#include <cmath>
#define INF 0x7fffffff
#define mst(a,b) memset(a,b,sizeof(a))
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int maxn=1e6+5;
ll ans[maxn];
int main()
{
ll n,m;
mst(ans,0);
while(cin>>n>>m&&n){
ans[0]=1;
if(n-m<m)
m=n-m;
else{
for(int i=1;i<=m;i++)
ans[i]=(n-i+1)*ans[i-1]/i;
}
cout<<ans[m]<<endl;
}
return 0;
}