680: Jack Straws

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=20;
int f[N],n;
struct node{
	int x,y;
}p[N],q[N];
int check(int i,int j){
	if (max(q[i].x,p[i].x)<min(q[j].x,p[j].x)||
		max(q[i].y,p[i].y)<min(q[j].y,p[j].y)||
		max(q[j].x,p[j].x)<min(q[i].x,p[i].x)||
		max(q[j].y,p[j].y)<min(q[i].y,p[i].y))	
		return 0;
	
	int u=(p[j].x-p[i].x)*(q[i].y-p[i].y)-(q[i].x-p[i].x)*(p[j].y-p[i].y);
	int v=(q[j].x-p[i].x)*(q[i].y-p[i].y)-(q[i].x-p[i].x)*(q[j].y-p[i].y);
	int w=(q[i].x-p[j].x)*(q[j].y-p[j].y)-(q[j].x-p[j].x)*(q[i].y-p[j].y);
	int z=(p[i].x-p[j].x)*(q[j].y-p[j].y)-(q[j].x-p[j].x)*(p[i].y-p[j].y);
	return (u*v<=0&&w*z<=0);
}
int get(int x){
	return x==f[x]?x:f[x]=get(f[x]);
}
void union_set(){
	for(int i=1;i<=n;i++)
	{
		for(int j=i+1;j<=n;j++)	if(check(i,j))	f[get(i)]=get(j);
	}
}
int main(){
	while(cin>>n){
		for(int i=1;i<=n;i++)	f[i]=i;
		for(int i=1;i<=n;i++)	cin>>p[i].x>>p[i].y>>q[i].x>>q[i].y;
		union_set();
		int a,b;
		while(cin>>a>>b,a||b){
			if(get(a)==get(b))	cout<<"CONNECTED"<<endl;
			else	cout<<"NOT CONNECTED"<<endl;
		}
	}
	return 0;
}
相关推荐
2501_9412362116 分钟前
C++与Node.js集成
开发语言·c++·算法
晨非辰18 分钟前
【数据结构初阶系列】归并排序全透视:从算法原理全分析到源码实战应用
运维·c语言·数据结构·c++·人工智能·python·深度学习
云边有个稻草人3 小时前
部分移动(Partial Move)的使用场景:Rust 所有权拆分的精细化实践
开发语言·算法·rust
泡沫冰@5 小时前
数据结构(20)
数据结构
松涛和鸣5 小时前
11.C 语言学习:递归、宏定义、预处理、汉诺塔、Fibonacci 等
linux·c语言·开发语言·学习·算法·排序算法
2501_941111246 小时前
C++与自动驾驶系统
开发语言·c++·算法
2501_941111697 小时前
C++中的枚举类高级用法
开发语言·c++·算法
jz_ddk7 小时前
[算法] 算法PK:LMS与RLS的对比研究
人工智能·神经网络·算法·信号处理·lms·rls·自适应滤波
Miraitowa_cheems7 小时前
LeetCode算法日记 - Day 106: 两个字符串的最小ASCII删除和
java·数据结构·算法·leetcode·深度优先
旭编7 小时前
小红的好矩形
c++·算法