Я читал возможные эффективные методы вычисления ncr
, когда наткнулся на этот пост.
Какой способ расчета nCr лучше
Второй ответ, данный здесь, я не могу этого понять. Код:
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;
}
И в чем будет сложность для этого? Я попытался сделать это на примере, и ответ получился правильным, но каковы эти условия?