Submission #66576679


Source Code Expand

#include<bits/stdc++.h>
using namespace std;
#define endl '\n'
#define int long long
const int N=3e5+10;
int dx[]={0,1,0,-1},dy[]={1,0,-1,0};
map<int,int> mp;
int n,m,k;
int a[N],b[N];
void slove(){
    cin>>n>>m;
    for(int i=1;i<n;i++) cin>>a[i];
    if(m%3!=0) cout<<0<<endl;
    else{
        int x=m/3;
        mp[0]++;
        int sum=0;
        for(int i=1;i<n;i++){
            sum+=a[i];
            sum%=m;
            mp[sum]++;
            // cout<<sum<<' ';
        }
        // cout<<endl;
        int ans=0;
        for(int i=0;i<=m/2;i++){
            if(mp[i]!=0&&mp[i+x]!=0&&mp[i+2*x]!=0){
                ans+=mp[i]*mp[i+x]*mp[i+2*x];
                mp[i]=mp[i+x]=mp[i+2*x]=0;
            }
        }
        cout<<ans<<endl;
    }
}
signed main(){
ios::sync_with_stdio(false);
cin.tie(nullptr);
    int T=1;
    // cin>>T;
    while(T--){
        slove();
    }
}

Submission Info

Submission Time
Task C - Equilateral Triangle
User Maikan
Language C++ 20 (gcc 12.2)
Score 300
Code Size 927 Byte
Status AC
Exec Time 145 ms
Memory 23380 KiB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 300 / 300
Status
AC × 3
AC × 37
Set Name Test Cases
Sample 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt
All 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt, 01_test_00.txt, 01_test_01.txt, 01_test_02.txt, 01_test_03.txt, 01_test_04.txt, 01_test_05.txt, 01_test_06.txt, 01_test_07.txt, 01_test_08.txt, 01_test_09.txt, 01_test_10.txt, 01_test_11.txt, 01_test_12.txt, 01_test_13.txt, 01_test_14.txt, 01_test_15.txt, 01_test_16.txt, 01_test_17.txt, 01_test_18.txt, 01_test_19.txt, 01_test_20.txt, 01_test_21.txt, 01_test_22.txt, 01_test_23.txt, 01_test_24.txt, 01_test_25.txt, 01_test_26.txt, 01_test_27.txt, 01_test_28.txt, 01_test_29.txt, 01_test_30.txt, 01_test_31.txt, 01_test_32.txt, 01_test_33.txt
Case Name Status Exec Time Memory
00_sample_00.txt AC 1 ms 3500 KiB
00_sample_01.txt AC 1 ms 3356 KiB
00_sample_02.txt AC 1 ms 3384 KiB
01_test_00.txt AC 1 ms 3492 KiB
01_test_01.txt AC 1 ms 3448 KiB
01_test_02.txt AC 8 ms 4476 KiB
01_test_03.txt AC 26 ms 5844 KiB
01_test_04.txt AC 3 ms 4544 KiB
01_test_05.txt AC 3 ms 4404 KiB
01_test_06.txt AC 42 ms 6456 KiB
01_test_07.txt AC 43 ms 6444 KiB
01_test_08.txt AC 18 ms 10624 KiB
01_test_09.txt AC 14 ms 8132 KiB
01_test_10.txt AC 94 ms 15880 KiB
01_test_11.txt AC 119 ms 16412 KiB
01_test_12.txt AC 25 ms 12740 KiB
01_test_13.txt AC 25 ms 13248 KiB
01_test_14.txt AC 71 ms 19100 KiB
01_test_15.txt AC 145 ms 23380 KiB
01_test_16.txt AC 1 ms 3420 KiB
01_test_17.txt AC 1 ms 3532 KiB
01_test_18.txt AC 8 ms 4812 KiB
01_test_19.txt AC 16 ms 5704 KiB
01_test_20.txt AC 15 ms 5808 KiB
01_test_21.txt AC 15 ms 5796 KiB
01_test_22.txt AC 15 ms 5768 KiB
01_test_23.txt AC 14 ms 5768 KiB
01_test_24.txt AC 15 ms 5784 KiB
01_test_25.txt AC 15 ms 5788 KiB
01_test_26.txt AC 140 ms 23012 KiB
01_test_27.txt AC 15 ms 5792 KiB
01_test_28.txt AC 15 ms 5760 KiB
01_test_29.txt AC 15 ms 5800 KiB
01_test_30.txt AC 14 ms 5764 KiB
01_test_31.txt AC 11 ms 5700 KiB
01_test_32.txt AC 12 ms 5788 KiB
01_test_33.txt AC 1 ms 3484 KiB