# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
715947 | 2023-03-28T14:46:22 Z | Ahmed57 | Ili (COI17_ili) | C++14 | 3 ms | 4948 KB |
#include <bits/stdc++.h> using namespace std; vector<int> adj[200001]; int n,m; int num(string s){ int add = 0; if(s[0]=='c')add = n; long long ans = 0; for(int i = 1;i<s.size();i++){ ans=ans*10+(s[i]-'0'); } return ans+add; } signed main(){ //ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0); cin>>n>>m; string s;cin>>s; for(int i = 1;i<=m;i++){ string a1,a2;cin>>a1>>a2; adj[i+n].push_back(num(a1)); adj[i+n].push_back(num(a2)); } queue<int> q; int ze[n+m+5] = {0}; int on[n+m+5] = {0}; for(int i = 0;i<s.size();i++){ if(s[i]=='0'){ q.push(i+n+1); ze[i+n+1] = 1; }else if(s[i]=='1'){ on[i+n+1] = 1; } } while(!q.empty()){ int w = q.front();q.pop(); for(auto j:adj[w]){ if(!ze[j]){ ze[j] = 1; q.push(j); } } } for(int i = n+1;i<=n+m;i++){ if(s[i-n-1]=='1'){ if(ze[adj[i][0]]){ on[adj[i][1]] = 1; }if(ze[adj[i][1]]){ on[adj[i][0]] = 1; } }if(s[i-n-1]=='?'){ if(ze[adj[i][0]]&&ze[adj[i][1]])ze[i] = 1; } } bitset<20001> v[n+m+1]; vector<int> ones; for(int i =1 ;i<=n;i++){ v[i][i] = 1; if(on[i]){ ones.push_back(i); } } for(int i = n+1;i<=n+m;i++){ v[i] = (v[adj[i][0]]^v[adj[i][1]]); if(s[i-n-1]!='?'){ if(s[i-n-1]=='1')ones.push_back(i); cout<<s[i-n-1]; } else{ if(ze[i]){ cout<<'0'; continue; }else{ if(on[i]){ cout<<'1'; ones.push_back(i); continue; } bool ss = 0; for(auto j:ones){ if((v[j]&v[i]).count()==v[j].count()){ ss = 1; break; } } if(ss){ cout<<'1'; ones.push_back(i); continue; } cout<<'?'; } } } }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 3 ms | 4948 KB | Output is correct |
2 | Correct | 3 ms | 4948 KB | Output is correct |
3 | Incorrect | 3 ms | 4948 KB | Output isn't correct |
4 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 3 ms | 4948 KB | Output is correct |
2 | Correct | 3 ms | 4948 KB | Output is correct |
3 | Incorrect | 3 ms | 4948 KB | Output isn't correct |
4 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 3 ms | 4948 KB | Output is correct |
2 | Correct | 3 ms | 4948 KB | Output is correct |
3 | Incorrect | 3 ms | 4948 KB | Output isn't correct |
4 | Halted | 0 ms | 0 KB | - |