ncr
この投稿に出くわしたとき、私は可能な効率的な計算方法を読んでいました
。
ここで与えられた2番目の答えは、私には理解できません。コードは次のとおりです。
long long combi(int n,int k)
{
long long ans=1;
k=k>n-k?n-k:k;
int j=1;
for(;j<=k;j++,n--)
{
if(n%j==0)
{
ans*=n/j;
}else
if(ans%j==0)
{
ans=ans/j*n;
}else
{
ans=(ans*n)/j;
}
}
return ans;
}
そして、これの複雑さは何ですか?例でやってみたら正解が出たのですが、その条件は何ですか?