记录编号 228678 评测结果 AAAAAAAAAA
题目名称 岛国 最终得分 100
用户昵称 Gravatarliu_runda 是否通过 通过
代码语言 C++ 运行时间 0.172 s
提交时间 2016-02-19 14:49:55 内存使用 0.31 MiB
显示代码纯文本
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn = 5010;
int ufs[maxn];
int find(int x){
	if(x==ufs[x])return x;
	else return ufs[x]=find(ufs[x]);
}
void link(int a,int b){
	ufs[find(a)]=find(b);
}
bool linked(int a,int b){
	return find(a)==find(b);
}
struct land{
	int x1,x2,y1,y2;
}data[5010];
bool cmp(const land &a,const land &b){
	return a.x1<b.x1;
}
int ylinked(int a,int b){
	if(data[a].y1-1>data[b].y2||data[b].y1-1>data[a].y2)return -1;  ///-1:no link 1:link 0:???
	if(data[a].y1-1==data[b].y2||data[b].y1-1==data[a].y2)return 0;
	else return 1;
}
int read(){
	int x=0;char ch;
	while(ch=getchar(),ch<'0'||ch>'9');
	x=ch-48;
	while(ch=getchar(),ch<='9'&&ch>='0')x=(x<<3)+(x<<1)+ch-48;
	return x;
}
int main(){
	freopen("jx.in","r",stdin);
	freopen("jx.out","w",stdout);
	int n;
	n=read();
	for(int i = 1;i<=n;++i){
		ufs[i]=i;
		data[i].x1=read();data[i].y1=read();data[i].x2=read();data[i].y2=read();
//		scanf("%d %d %d %d",&data[i].x1,&data[i].y1,&data[i].x2,&data[i].y2);
	}
	int tot=n; 
	sort(data+1,data+n+1,cmp);//之前写成了sort(data,data+n,cmp)....居然过了7个点 
	for(int i = 1;i<n;++i){
		for(int j = i+1;data[i].x2+1>=data[j].x1&&j<=n;++j){
			if(data[i].x2+1==data[j].x1){
				if(ylinked(i,j)==1&&find(i)!=find(j)){
					link(i,j);
					tot--;
				}
			}
			else {
				if(ylinked(i,j)!=-1&&find(i)!=find(j)){
					link(i,j);
					tot--;
				}
			}
		}
	}
	printf("%d",tot);
	fclose(stdin);fclose(stdout);
	return 0;
}