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^91n1040x,y109,小数点后的数字个数是 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一开始要赋值

posted @   辛夸高岭桂  阅读(56)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示