热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

POJ平面最近点对

描述二维平面上有N个点,求最近点对之间的距离。输入第一行一个整数T,表示有T组测试数据每组测试数据第一行一个整数N(2<N<1e5)表示平面有N个点接下来有N行,每行两个整数X

描述

二维平面上有N个点,求最近点对之间的距离。

输入第一行一个整数T,表示有T组测试数据
每组测试数据第一行一个整数N(2<=N<=1e5)表示平面有N个点
接下来有N行,每行两个整数X Y(-1e9<=X,Y <=1e9)表示点的坐标输出输出最近点对的距离,精确到小数点后6位样例输入

1
3
1 0
1 1
0 1

样例输出

1.000000




#include 
#include 
#include <string.h>
#include 
#include 
#include 
#include 
#include 
#include <string.h>
#include 
#include 
#include 

#define INF 0x3f3f3f3f

using namespace std;

struct point{
    double x, y;
    point(double x, double y) :x(x), y(y){};
};
vector vr;
bool cmpx(point a, point b){
    return a.x < b.x;
}
bool cmpy(int a, int b){
    return vr[a].y < vr[b].y;
}
double getdis(point a,point b){
    return sqrt(pow(a.x-b.x,2)+pow(a.y-b.y,2));
}
double mind(double a, double b){
    return a  a : b;
}

double fun(int left, int right){
    if (left + 1 == right) return getdis(vr[left], vr[right]);
    if (left + 2 == right)return mind(getdis(vr[left], vr[left + 1]), mind(getdis(vr[left], vr[right]), getdis(vr[left + 1], vr[right])));
    int mid = (left + right) >> 1;
    double d = mind(fun(left, mid), fun(mid + 1, right));
    vector<int>tv;
    for (int i = left; i <= right; i++){
        if (abs(vr[i].x - vr[mid].x) < d) tv.push_back(i);
    }
    sort(tv.begin(), tv.end(), cmpy);
    for (int i = 0; i 1; i++)
    for(int j=i+1;j){
        if (abs(vr[tv[i]].y - vr[tv[j]].y) < d)
            d = mind(d, getdis(vr[tv[i]], vr[tv[j]]));
    }
    return d;
}


int main()
{
    int T,N;
    double a, b;
    scanf("%d", &T);
    while (T--){
        vr.clear();
        scanf("%d", &N);
        for (int i = 0; i ){
            scanf("%lf %lf", &a, &b);
            vr.push_back(point(a, b));
        }
        sort(vr.begin(), vr.end(), cmpx);
        printf("%.6lf\n",fun(0, N - 1));
    }
    return 0;
}

 


推荐阅读
  • 题面:P3178[HAOI2015]树上操作好像其他人都嫌这道题太容易了懒得讲,好吧那我讲。题解:第一个操作和第二个操作本质上是一样的&# ... [详细]
  • 来自FallDream的博客,未经允许,请勿转载,谢谢。一天一套noi简直了.昨天勉强做完了noi2011今天教练又丢出来一套noi ... [详细]
  • 在学习了Splay树的基本查找功能后,可能会觉得它与普通的二叉查找树没有太大的区别,仅仅是通过splay操作减少了时间开销。然而,Splay树之所以被誉为“序列之王”,主要在于其强大的区间操作能力。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 使用 ModelAttribute 实现页面数据自动填充
    本文介绍了如何利用 Spring MVC 中的 ModelAttribute 注解,在页面跳转后自动填充表单数据。主要探讨了两种实现方法及其背后的原理。 ... [详细]
  • 我在尝试将组合框转换为具有自动完成功能时遇到了一个问题,即页面上的列表框也被转换成了自动完成下拉框,而不是保持原有的多选列表框形式。 ... [详细]
  • 本文介绍了一种在 Android 开发中动态修改 strings.xml 文件中字符串值的有效方法。通过使用占位符,开发者可以在运行时根据需要填充具体的值,从而提高应用的灵活性和可维护性。 ... [详细]
  • 解决Expo XDE 2.22.1版本启动错误
    根据问题描述,用户在将Expo升级至2.22.1版本后,在尝试打开项目时遇到了错误。本文提供了详细的错误分析及解决方案。 ... [详细]
  • HDU 2537 键盘输入处理
    题目描述了一个名叫Pirates的男孩想要开发一款键盘输入软件,遇到了大小写字母判断的问题。本文提供了该问题的解决方案及实现方法。 ... [详细]
  • 本文介绍了一种使用链剖分(Link-Cut Tree, LCT)来维护动态树结构的方法,特别是如何通过 LCT 来高效地管理子树的信息,如子树大小等。 ... [详细]
  • Docker基础入门与环境配置指南
    本文介绍了Docker——一款用Go语言编写的开源应用程序容器引擎。通过Docker,用户能够将应用及其依赖打包进容器内,实现高效、轻量级的虚拟化。容器之间采用沙箱机制,确保彼此隔离且资源消耗低。 ... [详细]
  • iOS如何实现手势
    这篇文章主要为大家展示了“iOS如何实现手势”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“iOS ... [详细]
  • Hadoop MapReduce 实战案例:手机流量使用统计分析
    本文通过一个具体的Hadoop MapReduce案例,详细介绍了如何利用MapReduce框架来统计和分析手机用户的流量使用情况,包括上行和下行流量的计算以及总流量的汇总。 ... [详细]
  • 本文探讨了在 APICloud 平台使用 execScript 方法时如何正确传递对象参数,并提供了详细的示例和解释。 ... [详细]
  • Java连接MySQL数据库的方法及测试示例
    本文详细介绍了如何安装MySQL数据库,并通过Java编程语言实现与MySQL数据库的连接,包括环境搭建、数据库创建以及简单的查询操作。 ... [详细]
author-avatar
Aries小阳光
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有