Submission #767375

#TimeUsernameProblemLanguageResultExecution timeMemory
767375t6twotwoDigital Circuit (IOI22_circuit)C++17
18 / 100
3083 ms3588 KiB
#include "circuit.h" #include <bits/stdc++.h> using namespace std; using ll = long long; constexpr int mod = 1000002022; int add(int x, int y) { int z = x + y; if (z >= mod) { z -= mod; } return z; } int sub(int x, int y) { int z = x - y; if (z < 0) { z += mod; } return z; } int mul(int x, int y) { return (ll)x * y % mod; } int N, M; vector<int> P, A; void init(int n, int m, vector<int> p, vector<int> a) { N = n, M = m; P = p, A = a; } int count_ways(int L, int R) { vector dp(N, vector{1}); vector<int> on(N + M), off(N + M); for (int i = L; i <= R; i++) { A[i - N] ^= 1; } for (int i = N + M - 1; i >= 0; i--) { if (i >= N) { on[i] = A[i - N]; off[i] = 1 - on[i]; } else { int sum = 0; for (int j = dp[i].size() - 1; j; j--) { sum = add(sum, dp[i][j]); on[i] = add(on[i], sum); } sum = dp[i][0]; for (int j = 1; j < dp[i].size(); j++) { off[i] = add(off[i], sum); sum = add(sum, dp[i][j]); } } if (i) { int K = dp[P[i]].size(); dp[P[i]].resize(K + 1); for (int j = K; j; j--) { dp[P[i]][j] = add(mul(dp[P[i]][j], off[i]), mul(dp[P[i]][j - 1], on[i])); } dp[P[i]][0] = mul(dp[P[i]][0], off[i]); } } return on[0]; }

Compilation message (stderr)

circuit.cpp: In function 'int count_ways(int, int)':
circuit.cpp:46:31: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   46 |             for (int j = 1; j < dp[i].size(); j++) {
      |                             ~~^~~~~~~~~~~~~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...