P1749 平面最近点对
题目描述
给定平面上 nn 个点,找出其中的一对点的距离,使得在这 nn 个点的所有点对中,该距离为所有点对中最小的。
输入格式
第一行一个整数 nn,表示点的个数,nn 不超过 10001。
接下来 nn 行,每行两个实数 x,yx,y,表示一个点的行坐标和列坐标。
输出格式
仅一行,一个实数,表示最短距离,四舍五入保留 44 位小数。
输入输出样例
Copy to Clipboard
3
1 1
1 2
2 2
输出
Copy to Clipboard
1.0000
说明 / 提示
数据规模与约定 对于 100\%100% 的数据,保证 1 \leq n \leq 10^4 0 \leq x, y \leq 10^91≤n≤1040≤x,y≤109,小数点后的数字个数是 44。
#include<iostream> #include<algorithm> #include<iomanip> #include<cmath> #define INF 0x3f3f3f3f using namespace std; int main(){ int n; cin>>n; double min=INF,temp=INF; // cout<<min; long long int x[n],y[n]; for(int i=1;i<=n;i++) cin>>x[i]>>y[i]; for(int i=1;i<=n;i++){ for(int j=1;j<=n;j++) { if(i!=j) temp=sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j])); if(temp<min) min=temp; } } // cout<<min; printf("%.4lf",min); return 0; }
暴力。如果循环像我这么写,temp一开始要赋值
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通