Problem about sum of nCr % M, when n > M (Dhaka Regional 2013)
Разница между en1 и en2, 18 символ(ов) изменены
[This](https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=629&page=show_problem&problem=4666) problem's solution ends up at↵

nCr(A+B-i, i) * nCr(A+B-2i, A-i) * pow(x, A-i) * pow(y, B-i) * pow(z, i) ; for every 0 <= i <= min(A, B)↵

All inputs are between 1 and 10^17 inclusive, and result should be printed as (result % M); where M = 1e6 + 3↵

I've seen a solution like this↵


~~~~~↵
while(A || B)↵
{↵
        u = A % M;↵
        v = B % M;↵
        tmp = 0;↵
        for ( i = 0; i <= min(u, v); i++)↵
        {↵
                tmp = (tmp + nCr(u+v-i, i) * nCr(u+v-2i, u-i) * pow(x, u-i) * pow(y, v-i) * pow(z, i)) % M;↵
        }↵
        ans = (ans * tmp) % M;↵
        A /= M;↵
        B /= M;↵
}↵
~~~~~↵


Full Source Code: [link](http://paste.ubuntu.com/13110831/)↵

Can you please explain how did he derive this?

История

 
 
 
 
Правки
 
 
  Rev. Язык Кто Когда Δ Комментарий
en2 Английский kfoozminus 2015-11-05 10:23:19 18
en1 Английский kfoozminus 2015-11-05 10:21:46 909 Initial revision (published)