思维 + 暴力 CodeForces - 1305C

Problem Description

To become the king of Codeforces, Kuroni has to solve the following problem.

He is given n numbers a1,a2,…,an. Help Kuroni to calculate ∏1≤i

If you are not familiar with short notation, ∏1≤i

Input

The first line contains two integers n, m (2≤n≤2⋅105, 1≤m≤1000) — number of numbers and modulo.

The second line contains n integers a1,a2,…,an (0≤ai≤109).

Output

Output the single number — ∏1≤i

很失败,思考方向走错了,心里想着怎么化简来着,明明做过很多数论的题,这道还是想错了,以后遇到 mod 的题要先考虑是不是为零的情况。加油啊,你的发量经不起这么耗了,拿出点 实力来啊!!

#include 
#include 

using namespace std;

typedef long long LL;

const int N = 300100;

int a[N];


int main()
{
    int n, m; cin >> n >> m;
    
    for(int i = 1; i <= n ; i ++)  scanf("%d", a + i);
    
    if(n > m) // 若 n > m,则肯定会存在两个 %m 相同的数 a1 和 a2,即 (a1 - a2) % m == 0,得出结果肯定为0
    {
        cout << 0 << endl;
        return 0;
    }
    else 
    {
        LL res = 1;
        for(int i = 1; i <= n ; i ++)
        {
            for(int j = i + 1; j <= n; j ++)
            {
                res = res * abs(a[i] - a[j]) % m;
            }
        }
        cout << res << endl;
    }
    return 0;
}

你可能感兴趣的:(思维 + 暴力 CodeForces - 1305C)