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;
}
相关推荐
hoiii1872 分钟前
MATLAB实现Canny边缘检测算法
算法·计算机视觉·matlab
qq_4308558816 分钟前
线代第二章矩阵第四课:方阵的幂
算法·机器学习·矩阵
roman_日积跬步-终至千里20 分钟前
【计算机设计与算法-习题2】动态规划应用:矩阵乘法与钢条切割问题
算法·矩阵·动态规划
kupeThinkPoem21 分钟前
计算机算法导论第三版算法视频讲解
数据结构·算法
sali-tec23 分钟前
C# 基于halcon的视觉工作流-章67 深度学习-分类
开发语言·图像处理·人工智能·深度学习·算法·计算机视觉·分类
少许极端26 分钟前
算法奇妙屋(十八)-子数组系列(动态规划)
算法·动态规划·子数组
WBluuue26 分钟前
Codeforces 1068 Div2(ABCD)
c++·算法
Solar20251 小时前
企业数据采集系统的架构设计与工程实践:从数据孤岛到智能决策的破局之道
数据结构
阿沁QWQ1 小时前
C++的map和set
开发语言·c++
地平线开发者1 小时前
征程 6P/H 计算平台部署指南
算法·自动驾驶