# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
867071 | 2023-10-27T16:25:11 Z | HoriaHaivas | Parametriziran (COCI19_parametriziran) | C++14 | 1570 ms | 65536 KB |
/* "care a facut teste cu Lattice reduction attack e ciudat" "linistiti va putin" - 2023 - */ #include<bits/stdc++.h> #define debug(x) cerr << #x << " " << x << "\n" #define debugs(x) cerr << #x << " " << x << " " #warning ai grija la ? ca l ai transformat in { #pragma GCC optimize("Ofast") using namespace std; const int mod=1e9+9; const int base=29; string s[50001]; map<int,int> hashcount[(1<<7)]; int main() { ifstream fin(".in"); ofstream fout(".out"); ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int i,j,n,m,ans,mask,hashbuild,mask2; bool ok; cin >> n >> m; for (j=1; j<=n; j++) { cin >> s[j]; for (i=0; i<s[j].size(); i++) { if (s[j][i]=='?') s[j][i]='{';///urmatorul caracter dupa z } for (mask=1; mask<(1<<(m+1)); mask++) { hashbuild=0; for (i=0; i<s[j].size(); i++) { if (mask&(1<<i)) hashbuild=((hashbuild*base)%mod+(s[j][i]-'a'+1))%mod; } hashcount[mask][hashbuild]++; } } ans=0; for (j=1; j<=n; j++) { mask=0; for (i=0; i<s[j].size(); i++) { if (s[j][i]!='{') { mask=mask|(1<<i); } } if (mask!=0) { for (mask2=0; mask2<=mask; mask2++) { ok=true; for (i=0; i<s[j].size() && ok; i++) { if ((mask2&(1<<i)) && !(mask&(1<<i))) ok=false; } if (ok) { hashbuild=0; for (i=0; i<s[j].size(); i++) { if (mask&(1<<i)) { if (mask2&(1<<i)) hashbuild=((hashbuild*base)%mod+('{'-'a'+1))%mod; else hashbuild=((hashbuild*base)%mod+(s[j][i]-'a'+1))%mod; } } ans+=hashcount[mask][hashbuild]; } } } else { ans+=n; } } cout << (ans-n)/2; return 0; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 8 ms | 1884 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 14 ms | 1884 KB | Output is correct |
2 | Correct | 10 ms | 1884 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 15 ms | 2108 KB | Output is correct |
2 | Correct | 27 ms | 2100 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 50 ms | 3156 KB | Output is correct |
2 | Correct | 27 ms | 2480 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 57 ms | 2896 KB | Output is correct |
2 | Correct | 76 ms | 4868 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 316 ms | 13896 KB | Output is correct |
2 | Correct | 66 ms | 3152 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 718 ms | 31276 KB | Output is correct |
2 | Correct | 115 ms | 4528 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 1297 ms | 53588 KB | Output is correct |
2 | Correct | 565 ms | 27040 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Runtime error | 1570 ms | 65536 KB | Execution killed with signal 9 |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Runtime error | 1323 ms | 65536 KB | Execution killed with signal 9 |
2 | Halted | 0 ms | 0 KB | - |