Submission #1004939

#TimeUsernameProblemLanguageResultExecution timeMemory
1004939vjudge1Street Lamps (APIO19_street_lamps)C++17
0 / 100
107 ms23832 KiB
#include<bits/stdc++.h> using namespace std; #define toggle 1 #define query 2 int n, q; string s; vector<vector<int> > Q; void subtask1() { int cnt[n + 1][n + 1]; memset(cnt, 0, sizeof(cnt)); int pref[n + 1]; pref[0] = 0; for(int i = 0; i < n; i ++) pref[i + 1] = pref[i] + s[i] - '0'; for(auto qy : Q) { if(qy[0] == toggle) { s[qy[1]] = '1' + '0' - s[qy[1]]; pref[0] = 0; for(int i = 0; i < n; i ++) pref[i + 1] = pref[i] + s[i] - '0'; } else { for(int i = 0; i <= n; i ++) for(int j = i + 1; j <= n; j ++) if(pref[j] - pref[i] == j - i) cnt[i][j]++; cout << cnt[qy[1]][qy[2]] << '\n'; } } } void subtask2() { } int main() { cin >> n >> q; cin >> s; for(int i = 0; i < q; i ++) { string cmd; cin >> cmd; if(cmd == "toggle") { int x; cin >> x; x--; Q.push_back({toggle, x}); } else { int a, b; cin >> a >> b; a--, b--; Q.push_back({query, a, b}); } } if(max(n, q) <= 100) subtask1(); else subtask2(); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...