COJ 1163: 寒衣调

Description

男从戎,女守家。一夜,狼烟四起,男战死沙场。从此一道黄泉,两地离别。最后,女终于在等待中老去逝去。逝去的最后是换尽一生等到的相逢和团圆。
某日两人至奈何桥前,服下孟婆汤。
每滴孟婆汤都有强度不一的药效,设一碗孟婆汤共N滴(0<N<100000),其中第i滴(0≤i<N)用b[i]表示。
孟婆汤的药效与原料有关,设熬制前同样有N滴原料,第i滴原料用a[i]表示,0≤a[i]<2^32。
药效b[i]的计算方法为b[i]=(a[0]*a[1]*...*a[N-1]/a[i])%m(假设0/0=1),0<b[i]<2^32。

Input

每行开头给出原料数量N,取模数m,紧接着的一行按顺序给出原料a[i]。求出熬制所成孟婆汤的药效b[i],每次输完一碗孟婆汤的药效后以换行结尾。

Output

 求出熬制所成孟婆汤的药效b[i],每碗孟婆汤后以换行结尾。

Sample Input

5 11
2 7 5 3 9
3 7
9 8 5

Sample Output

10 6 4 3 1
5 3 2

这题写得非常有范是吧?问题主要涉及扩展欧几里得算法和乘法逆元的一些问题,下面直接上代码了:

#include
#define MAXN 100005
int a[MAXN], b[MAXN];
int N, m;
int main()
{
    while(scanf( "%d%d", &N, &m) == 2){
        for(int i = 0; i < N; i++) scanf("%d",&a[i]);
        b[N] = 1;
        for(int i = N - 1; i >= 0; i --)
            b[i] = (long long)b[i + 1] * a[i] % m;

        for(int i = 1; i < N; i ++)
            a[i] = (long long)a[i - 1] * a[i] % m;

        printf( "%lld", (long long)b[1]);
        for(int i = 1; i < N; i ++)
            printf(" %lld", (long long)a[i - 1] * b[ i + 1] % m);
        printf("\n");
    }
    return 0;
}


你可能感兴趣的:(ACM题目)