省选专练(大水题)usaco2008feb-silver连线游戏

12 篇文章 0 订阅
11 篇文章 0 订阅
本文介绍了一种基于C++的排序与唯一化处理算法,该算法通过计算几何中的向量角来对向量进行排序,并使用手动唯一化处理去除重复元素。文中详细展示了Point结构体的定义及操作符重载方法,同时提供了完整的主函数流程,包括输入点集、计算向量、排序向量及计数唯一向量等步骤。
摘要由CSDN通过智能技术生成

貌似x/y排个序

手动unique就好了

#include<bits/stdc++.h>
using namespace std;
const double eps=1e-16;
const double INF=1e16;
int cmp(double A){
	if(fabs(A)<eps)return 0;
	else return(A>0)?1:-1;
}
bool equal(double A,double B){
	return (cmp(A-B)==0);
}
struct Point{
	double x,y;
	double Ang;
	Point(double _x=0.0,double _y=0.0):x(_x),y(_y){}
	friend Point operator + (Point A,Point B){return Point(A.x+B.x,A.y+B.y);}
	friend Point operator - (Point A,Point B){return Point(A.x-B.x,A.y-B.y);}
	friend Point operator * (Point A,double k){return Point(A.x*k,A.y*k);}
	friend Point operator / (Point A,double k){return Point(A.x/k,A.y/k);}
	void ang(){if(x!=0)Ang=y/x;else Ang=-1.23456789;}
	void read(){scanf("%lf%lf",&x,&y);}
}p[4000];
typedef Point Vectors;
double Cross(Vectors A,Vectors B){
	return (A.x*B.y-A.y*B.x);
}
Vectors len[50000];
int vis[50000]={};
int n;
int top=0;
bool cmpV(Vectors A,Vectors B){
	return (cmp(A.Ang-B.Ang)<0);
}
int main(){
	scanf("%d",&n);
	for(int i=1;i<=n;i++){
		p[i].read(); 
	}
	for(int i=1;i<=n;i++){
		for(int j=i+1;j<=n;j++){
			len[++top]=p[i]-p[j];
			len[top].ang();
		}
	} 
	sort(len+1,len+1+top,cmpV);
	int ans=0;
	len[0].Ang=-0.123456789;
	for(int i=1;i<=top;i++){
		if(!equal(len[i].Ang,len[i-1].Ang)){
//			cout<<len[i].Ang<<len[i].x<<" "<<len[i].y<<'\n';
			ans++;
		}
	}
	/*for(int i=1;i<=top;i++){
		if(!vis[i]){
			for(int j=i+1;j<=top;j++){
				if(!vis[j]&&cmp(Cross(len[i],len[j]))==0)vis[j]=1;
			}
		}
	}*/ 
	/*int ans=0;
	for(int i=1;i<=top;i++){
		if(!vis[i]){
			ans++;
//			cout<<len[i].x/len[i].y<<'\n';
		}
	}*/ 
	cout<<ans;
} 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值