QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#643203 | #9449. New School Term | icpc_zhzx034 | WA | 3ms | 11864kb | C++14 | 3.6kb | 2024-10-15 19:47:32 | 2024-10-15 19:47:33 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<ll,ll> Pr;
#define fi first
#define se second
#define mkp make_pair
#define pb emplace_back
// #define mid ((l+r)>>1)
#define popcnt __builtin_popcountll
inline ll read(){
ll x=0, f=1; char ch=getchar();
while(ch<'0' || ch>'9') { if(ch=='-') f=-1; ch=getchar(); }
while(ch>='0' && ch<='9') x=x*10+ch-'0', ch=getchar();
return x*f;
}
inline ll lg2(ll x){ return 63^__builtin_clzll(x); }
void init(){ }
const ll mod = 979532918953082881ll;
const ll N = 20000;
ll n,m,a[1000005],b[1000005];
ll fa[20005], sz[20005];
ll f[20005];
ll find(ll x){
if(x!=fa[x]) fa[x]=find(fa[x]);
return fa[x];
}
void addmod(ll &x){ (x >= mod) && (x -= mod); }
ll base;
void add(int u,int v){
// cout<<"add "<<u<<" "<<v<<endl;
if(u>v) swap(u, v); v-=u;
base += u;
for(int i=N;i>=v;i--) addmod(f[i]+=f[i-v]);
}
void del(int u,int v){
// cout<<"del "<<u<<" "<<v<<endl;
if(u>v) swap(u, v); v-=u;
base -= u;
if(v){
for(int i=v;i<=N;i++){
addmod(f[i]+=mod-f[i-v]);
}
}else{
for(int i=v;i<=N;i++){
if(f[i]&1) f[i]=((f[i]+mod)>>1);
else f[i]>>=1;
}
}
}
void merge(ll x,ll y){
x=find(x), y=find(y);
if(x==y) return;
if(x<y) swap(x, y);
fa[x] = y; sz[y] += sz[x];
}
int up[20005], down[20005], seq[20005], tl;
vector<int>vec[20005][2];
bitset<20005>dp[20005],jc[20005];
void print(){
for(ll i=0;i<=n;i++){
printf("%lld ", f[i]);
}
puts("");
}
bool ans[20005];
bool visq[20005];
void procedure(){
n=read()*2,m=read();
for(ll i=1;i<=m;i++){
a[i]=read(), b[i]=read();
}
for(ll i=1;i<=2*n;i++) sz[i]=(i<=n), fa[i]=i;
f[0] = 1;
for(ll i=1;i<=n;i++) add(0, 1);
// print();
// cout<<"firstly"<<endl;
for(ll i=m;i>=1;i--){
if(find(a[i]) == find(b[i]) || find(a[i]) == find(b[i]+n)) continue;
ll u1 = sz[find(a[i])], v1 = sz[find(a[i]+n)];
ll u2 = sz[find(b[i]+n)], v2 = sz[find(b[i])];
del(u1, u2); del(u2, v2);
add(u1+u2, v1+v2);
// print();
if(n/2 >= base && f[n/2-base]){
// cout<<"not same "<<a[i]<<" "<<b[i]<<endl;
merge(a[i], b[i]+n);
merge(a[i]+n, b[i]);
}else{
del(u1+u2, v1+v2);
add(u1+v2, v1+u2);
// cout<<"same "<<a[i]<<" "<<b[i]<<endl;
merge(a[i], b[i]);
merge(a[i]+n, b[i]+n);
}
// cout<<"time = "<<i<<endl;
}
// cout<<"solved"<<endl;
// for(ll i=1;i<=n;i++) printf("%lld ", find(i)); puts("");
// for(ll i=1;i<=n;i++) printf("%lld ", find(i+n)); puts("");
for(ll i=1;i<=2*n;i++){
if(i <= n) up[find(i)]++, vec[find(i)][0].pb(i);
else down[find(i)]++, vec[find(i)][1].pb(i-n);
}
for(ll i=1;i<=n;i++){
if(!vec[i][0].size() || visq[i]) continue;
seq[++tl] = i;
visq[find(i+n)] = 1;
}
// for(ll i=1;i<=tl;i++){
// cout<<seq[i]<<" "<<up[seq[i]]<<" "<<down[seq[i]]<<endl;
// }
dp[0][0] = 1;
for(ll i=1;i<=tl;i++){
for(ll j=0;j<=n/2;j++){
if(j >= up[seq[i]]){
if(dp[i-1][j-up[seq[i]]]){
jc[i][j] = 0;
dp[i][j] = 1;
}
}
if(j >= down[seq[i]]){
if(dp[i-1][j-down[seq[i]]]){
jc[i][j] = 1;
dp[i][j] = 1;
}
}
}
}
for(ll i=tl, j=n/2; i>=1; i--){
// cout<<"jc is "<<(bool)(jc[i][j])<<endl;
if(jc[i][j]){
for(auto x: vec[seq[i]][1]) ans[x] = 1;
j -= down[seq[i]];
}else{
for(auto x: vec[seq[i]][0]) ans[x] = 1;
j -= up[seq[i]];
}
}
for(ll i=1;i<=n;i++) putchar(ans[i]+'0');
puts("");
}
int main(){
#ifdef LOCAL
assert(freopen("input.txt","r",stdin));
assert(freopen("output.txt","w",stdout));
#endif
ll T=1;
init();
while(T--) procedure();
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 3ms
memory: 11848kb
input:
2 4 1 3 2 4 1 4 1 2
output:
0101
result:
ok Output is valid. OK
Test #2:
score: 0
Accepted
time: 0ms
memory: 11852kb
input:
3 7 2 5 1 3 4 6 2 6 4 5 2 4 5 6
output:
001101
result:
ok Output is valid. OK
Test #3:
score: 0
Accepted
time: 1ms
memory: 9676kb
input:
1 0
output:
10
result:
ok Output is valid. OK
Test #4:
score: 0
Accepted
time: 1ms
memory: 9800kb
input:
1 1 1 2
output:
01
result:
ok Output is valid. OK
Test #5:
score: 0
Accepted
time: 0ms
memory: 11864kb
input:
2 3 2 4 3 4 1 2
output:
0110
result:
ok Output is valid. OK
Test #6:
score: -100
Wrong Answer
time: 2ms
memory: 9724kb
input:
3 8 4 6 3 5 1 4 2 4 1 6 1 2 3 4 4 5
output:
100100
result:
wrong answer The number of 0s must be equal to that of 1s.