QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#520184#5504. Flower Garden123456xwdWA 4ms92112kbC++143.3kb2024-08-15 11:22:342024-08-15 11:22:35

Judging History

你现在查看的是最新测评结果

  • [2024-08-15 11:22:35]
  • 评测
  • 测评结果:WA
  • 用时:4ms
  • 内存:92112kb
  • [2024-08-15 11:22:34]
  • 提交

answer

#include<bits/stdc++.h>
#define int long long
#define p_b push_back
#define m_p make_pair
#define pii pair<int,int>
#define x first
#define y second
#define ls k<<1
#define rs k<<1|1
#define mid ((l+r)>>1)
#define gcd __gcd
#define lowbit(x) (x&(-x))
using namespace std;
int rd(){
	int x=0,f=1; char ch=getchar();
	for(;ch<'0'||ch>'9';ch=getchar())if (ch=='-') f=-1;
	for(;ch>='0'&&ch<='9';ch=getchar())x=(x<<1)+(x<<3)+(ch^48);
	return x*f;
}
const int N=1e6+5,INF=0x3f3f3f3f3f3f3f3f;
int n,m,tot;
vector<int> G[N],E[N],EE[N];
int t1[N],t2[N];
void add(int u,int v){
	G[u].p_b(v);
}
void build(int k,int l,int r){
	if(l==r){
		t1[k]=t2[k]=l;
		return;
	}
	t1[k]=++tot,t2[k]=++tot;
	build(ls,l,mid);build(rs,mid+1,r);
	add(t1[ls],t1[k]),add(t1[rs],t1[k]);
	add(t2[k],t2[ls]),add(t2[k],t2[rs]);
}
void add1(int k,int l,int r,int x,int y,int v){
	if(x<=l&&r<=y){
		add(t1[k],v);
		return;
	}
	if(x<=mid) add1(ls,l,mid,x,y,v);
	if(y>mid) add1(rs,mid+1,r,x,y,v);
}
void add2(int k,int l,int r,int x,int y,int u){
	if(x<=l&&r<=y){
		add(u,t2[k]);
		return;
	}
	if(x<=mid) add2(ls,l,mid,x,y,u);
	if(y>mid) add2(rs,mid+1,r,x,y,u);
}
int dfn[N],low[N],belong[N],siz[N],cnt,color;
bool vis[N];stack<int> q;
void tarjan(int u){
	dfn[u]=low[u]=++cnt;
	vis[u]=1,q.push(u);
	for(auto v : G[u]){
		if(!dfn[v]){
			tarjan(v);
			low[u]=min(low[u],low[v]);
		}
		else if(vis[v]) low[u]=min(low[u],dfn[v]);
	}
	if(dfn[u]==low[u]){
		color++;int v;
		do{
			v=q.top();q.pop();vis[v]=0;
			belong[v]=color,siz[color]+=(v<=n*3);
		}while(v!=u);
	}
}
int in[N],a[N],b[N];
bool c[N];
void print(){
	puts("TAK");
	for(int i=1;i<=n*3;i++) putchar(!c[belong[i]]?'R':'F');
	puts("");
}
void solve(){
	n=rd(),m=rd();
	tot=n*3;
	build(1,1,n*3);
	for(int i=1;i<=m;i++){
		int A,B,C,D,u;
		A=rd(),B=rd(),C=rd(),D=rd();
		u=++tot;
		add1(1,1,n*3,A,B,u);add2(1,1,n*3,C,D,u);
	}
	for(int i=1;i<=tot;i++) if(!dfn[i]) tarjan(i);
	for(int u=1;u<=tot;u++){
		for(auto v : G[u]){
			if(belong[v]==belong[u]) continue;
			E[belong[u]].p_b(belong[v]);
			EE[belong[v]].p_b(belong[u]);
			in[belong[u]]++;
		}
	}
	vector<int> vec;queue<int> Q;bool tag=0;
	for(int i=1;i<=color;i++){
		if(siz[i]>=n) vec.p_b(i);
	}
	
	for(int i=1;i<=color;i++) if(!in[i]) Q.push(i);
	int u,sum=0;
	while(!Q.empty()){
		u=Q.front();Q.pop();
		if(siz[u]>=n) continue;
		sum+=siz[u];c[u]=1;
		if(sum>=n&&sum<=2*n){
			print();
			return;
		}
		for(auto v : E[u]){
			in[v]--;
			if(!in[v]) Q.push(v);
		}
	}//>=n作为1
	for(auto u : vec){
		while(!Q.empty()) Q.pop();
		for(int i=1;i<=color;i++) c[i]=0,in[i]=E[i].size();
		for(int i=1;i<=color;i++) if(!in[i]) Q.push(i);
		c[u]=1;sum=0;
		while(!Q.empty()){
			u=Q.front();Q.pop();
			for(auto v : EE[u]){
				in[v]--;
				c[v]|=c[u];
				if(!in[v]) Q.push(v);
			}
		}
		for(int i=1;i<=color;i++) sum+=c[i]*siz[i];
		if(n<=sum&&sum<=2*n){
			print();
			return;
		}
	}
	puts("NIE");
}
void clean(){
	while(!q.empty()) q.pop();
	for(int i=1;i<=tot;i++){
		G[i].clear();
		dfn[i]=low[i]=0;
		belong[i]=siz[i]=0;
		vis[i]=0;
	}
	for(int i=1;i<=color;i++){
		E[i].clear(),EE[i].clear();
		c[i]=a[i]=b[i]=in[i]=0;
	}
	color=tot=cnt=0;
}
signed main(){
	int T=rd();
	while(T--){
		solve();
		clean();
	}
	return 0;
}

详细

Test #1:

score: 0
Wrong Answer
time: 4ms
memory: 92112kb

input:

2
1 3
1 1 2 2
1 2 3 3
1 1 3 3
1 3
1 1 2 2
2 2 3 3
3 3 1 1

output:

TAK
FFR
NIE

result:

wrong answer odpowiedz nie spelnia wymogow!