QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#579181 | #4564. Digital Circuit | ModyKachef# | 0 | 186ms | 11468kb | C++23 | 1.5kb | 2024-09-21 10:19:09 | 2024-09-21 10:19:14 |
Judging History
answer
#include "circuit.h"
#include <bits/stdc++.h>
#include <vector>
using namespace std;
#define ll long long
#pragma GCC optimize("trapv")
vector<int> a;
int n , m;
vector<ll> dp[2000] , dp2;
vector<vector<int>> adj;
vector<ll> pw;
const int mod = 1000002022;
// dp[i] = number of ways to make i = 1;
void dfs(int node){
if (node >= n) {dp[0][node]= a[node-n]; dp2[node]= 1; return;}
int c = adj[node].size();
dp2[node] = c;
for (auto i : adj[node]){
dfs(i);
}
for (int msk = 0 ; msk < (1<<c) ; msk++){
ll prod = 1;
for (int i = 0 ; i < c ; i++){
if (msk & (1<<i)) prod*=(dp[0][adj[node][i]]);
else prod *= (dp2[adj[node][i]] - dp[0][adj[node][i]])%mod;
}
dp[__builtin_popcountll(msk)-1][node] += prod;
dp[__builtin_popcountll(msk)-1][node] %= mod;
}
for (int j = c-1 ; j >=0 ; j--){
dp[j][node] += dp[j+1][node];
}
for (int j = c-1 ; j >= 0 ; j--){
dp[j][node] += dp[j+1][node];
}
}
void init(int N, int M, std::vector<int> P, std::vector<int> A) {
n= N, m = M; a = A;
pw.resize(N+M+1);
adj.assign(N+M , {});
for (int i = 1 ; i < N + M ; i++) adj[P[i]].push_back(i);
pw[0]= 1;
for (int i = 1 ; i <= N+M ; i++){
pw[i] = (pw[i-1] * 2)%mod;
}
}
int count_ways(int L, int R) {
for (int i = L ; i <= R ; i++) a[i-n] = (!a[i-n]);
for (int i = 0 ; i < 1000 ; i++) dp[i].assign(n+m+1 , 0);
dp2.assign(n+m+1 , 0);
dfs(0);
return dp[0][0]%mod;
}
Details
Tip: Click on the bar to expand more detailed information
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 2
Accepted
time: 0ms
memory: 4120kb
input:
1 2 -1 0 0 0 0 1 1 2 2 1 2 2 2 1 2 -1 -1 -2 -2
output:
1 2 0 1 1
result:
ok 7 lines
Test #2:
score: 2
Accepted
time: 1ms
memory: 3784kb
input:
1 1 -1 0 0 1 1 1 1 1 1 1 1 -1 -1 -2 -2
output:
1 0 1 0
result:
ok 6 lines
Test #3:
score: 0
Wrong Answer
time: 186ms
memory: 11468kb
input:
1 972 -1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0...
output:
0 0 0 0 0
result:
wrong answer 3rd lines differ - expected: '509', found: '0'
Subtask #2:
score: 0
Runtime Error
Test #9:
score: 7
Accepted
time: 1ms
memory: 3860kb
input:
1 2 -1 0 0 0 0 1 1 2 2 1 2 2 2 1 2 -1 -1 -2 -2
output:
1 2 0 1 1
result:
ok 7 lines
Test #10:
score: 0
Runtime Error
input:
255 256 -1 0 0 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 50 51 ...
output:
result:
Subtask #3:
score: 0
Skipped
Dependency #1:
0%
Subtask #4:
score: 0
Time Limit Exceeded
Test #43:
score: 0
Time Limit Exceeded
input:
32767 32768 -1 0 0 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 50...
output:
268730368 268713984 268730368 -731255270 -731238886 -731255270 268730368 -731255270 -731271654 268746752 268763136 268746752 268730368 268713984 268697600 268681216 268697600 268713984 268730368 -731288038 -731304422 -731288038 268730368 268746752 268763136 268746752 268730368 268713984 268697600 26...
result:
Subtask #5:
score: 0
Skipped
Dependency #4:
0%
Subtask #6:
score: 0
Skipped
Dependency #2:
0%
Subtask #7:
score: 0
Skipped
Dependency #3:
0%
Subtask #8:
score: 0
Skipped
Dependency #1:
0%