結果

問題 No.2709 1975 Powers
ユーザー marble72
提出日時 2024-03-31 14:49:55
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
TLE  
実行時間 -
コード長 1,058 bytes
コンパイル時間 4,322 ms
コンパイル使用メモリ 254,096 KB
最終ジャッジ日時 2025-02-20 17:27:48
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 1 TLE * 1 -- * 23
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
#include <atcoder/all>
using namespace std;
typedef long long ll;
using namespace atcoder;
typedef modint mint;

int main(){
    int  N,P,Q;
    cin >> N >> P >> Q;
    mint::set_mod(P);
    vector<int> A;
    for(int i=0;i<N;i++){
        int a;
        cin >> a;
        A.push_back(a);
    }
    sort(A.begin(),A.end());
    ll result = 0;
    for(int i=0;i<N;i++){
        mint ans = 0;
        mint a = mint(10).pow(A[i]);
        ans += a;
        for(int j=i+1;j<N;j++){
            mint b = mint(9).pow(A[j]);
            ans += b;
            for(int k=j+1;k<N;k++){
                mint c = mint(7).pow(A[k]);
                ans += c;
                for(int l=k+1;l<N;l++){
                    mint x = mint(5).pow(A[l]);
                    ans += x;
                    if(ans.val() == Q){
                        result++;
                    }
                    ans -= x;
                }
                ans -= c;
            }
            ans -= b;
        }
        ans -= a;
    }
    cout << result << endl;
}
0