随机增量法求解最小圆覆盖问题

news/2025/3/15 13:28:48/文章来源:https://www.cnblogs.com/Young-Cloud/p/18773552

过程

假设我们已经通过某种神秘的方法确定了前 \(i - 1\) 个点的圆 \(O\),这这时候我们考虑加入第 \(i\) 个点,此时,如果第 \(i\) 个点在圆 \(O\) 内(包括边界上),我们就可以认为前 \(i\) 个点的圆也是 \(O\),否则我们需要重新确定前 \(i\) 个点的最小圆覆盖。具体的方法就是……暴力:

  1. 首先第 \(i\) 个点一定在前 \(i\) 个点的圆的圆周上。所以我们初始化一个以第 \(i\) 个点为圆心,半径为 0 的圆。
  2. 有了初始化的圆,我们要根据前面的点去调整这个圆,如果不在圆内,那就调整圆心为两点的中点,半径为两点间距离的一半。
  3. 有了初步更新的圆,我们再根据前面的点去调整,如果不在圆内,就根据三个点调整圆心和半径。

根据以上步骤,我们得出了以下循环:

void solve() {// code ...// 将读入的点集重新排列// 防止被特定的数据卡std::random_shuffle(a, a + n);// 对于一个点,最小圆就是半径为 0 的。point O = a[0];double r = 0;// 逐步加入第 i 个点for (int i = 1; i < n; i++) {// 在圆就不变if (dis2(O, a[i]) - r <= EPS) {continue;}// 不在就重新确定圆O = a[i], r = 0;for (int j = 0; j < i; j++) {if (dis2(O, a[j]) - r <= EPS) {continue;}// 由两个点确定的最小圆O = cen(a[i], a[j]), r = dis2(O, a[j]);for (int k = 0; k < j; k++) {if (dis2(O, a[k]) - r <= EPS) {continue;}// 由三个点确定的最小圆O = cen(a[i], a[j], a[k]), r = dis2(O, a[i]);}}}// code ...
}

最后跑完就得到了所有点的最小圆,以上三个循环可以跑 \(10^5\) 的数据,据说时间复杂度还是 \(O(n)\) 的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/899157.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Arduino-多彩音乐蜂鸣器

利用Arduino Uno实现简易多彩音乐播放器。最近开始接触Arduino,利用它可以搭建一些电子系统,实现相关功能。本文所要介绍的就是利用全彩LED和蜂鸣器,搭建一个简易的多彩音乐播放器。 器材准备Arduino UNO R3开发板一块 5mm全彩LED(共阴极)一只 无源蜂鸣器一只 1k\(\Omega\…

82.7K star!大气炫酷UI开源项目,超级火!

shadcn/ui 是一款基于 Radix UI 和 Tailwind CSS 构建的现代化 UI 组件库,专为追求设计品质与开发效率的开发者打造。不同于传统组件库,它提供完全可定制的组件代码模板,让开发者既能享受开箱即用的便利,又能保持对设计系统的完全掌控。嗨,大家好,我是小华同学,关注我们…

20241415 实验一 《Python程序设计》实验报告

20241415 2024-2025-2 《Python程序设计》实验一报告 课程:《Python程序设计》 班级: 2414 姓名: 赵邵宁 学号:20241415 实验教师:王志强 实验日期:2025年3月12日 必修/选修: 公选课 1.实验内容 1.熟悉Python开发环境; 2.练习Python运行、调试技能;(编写书中的程序…

前后端分离开发:如何高效调试API?有工具 vs 无工具全解析

在前后端分离的开发模式中,API 的调试是非常重要的一部分。特别是使用 Java 作为后端开发时,保证接口的功能正确性、性能稳定性,以及响应数据的准确性,都是前端和后端高效协作的关键。本文将结合接口调试的实际开发场景,探讨在有调试工具和没有调试工具两种情况下,如何实…

服务器SSH 仅密钥登录

前言 随着我服务器上Alist资源的增多,服务器【本身】这个存放着Alist内所有密码(虽然都是随机生成的)的存在就显得非常的脆弱。 尽管我的ssh密码选择了随机生成并交给电脑记住,但是服务器被攻破导致全部密码我都得改一遍的后果我承担不起。 另注:因为上传到云盘的重要资料…

JDK7-日历类--java进阶day07

1.Calendar类 用于获取或者修改时间,之前学的Date类,获取和修改时间的方法已经过时2.Calendar对象的创建 Calendar类里面有很多抽象方法,如果创建对象就要全部重写,所以不能直接创建 我们可以使用多态解决创建对象的问题,由于其子类对象也较难创建,所以我们使用下图中的方…

Vue3-DeepSeek-Chat流式AI对话|vite6+vant4+deepseek智能ai聊天助手

原创新作vue3.5+deepseek+vant4+vant4仿DeepSeek-R1流式输出ai聊天对话。 deepseek-vue3-chat : 实战2025智能大模型ai会话,基于Vue3+Vite6+OpenAI集成接入DeepSeek聊天小助手模板,支持流式打字输出效果、浅色/暗黑主题模式、代码高亮显示、针对移动端+PC端适配处理。🐬使用…

Sections 多列混排

学习点@Reusable 装饰器 WaterFlow瀑布流容器 模块组件 代码讲解效果图@Reusable 装饰器使用场景 @Reusable 是一个在 HarmonyOS ArkTS 中使用的装饰器,主要用于自定义组件的复用。从 API version 10 开始,@Reusable 装饰器得到了支持。它的主要功能是当一个标记为 @Reusable…

后缀数组(SA)学习笔记(倍增算法)

倍增求SA后缀数组是一个非常好的东西。一开始看不出来这个东西有什么用,但是它非常的有用。(以下 \(N\) 为字符串长度) 有了后缀数组,我们就可以在 \(O(N \log N)\) 的时间内:得到所有后缀的字典序关系。(最基本的功能) 求出任意两个子串的最长公共前缀 (LCP)。 求出字符…

Chat2DB 数据库客户端邀请码

推荐一款超好用的AI数据库管理工具Chat2DB,支持22种数据库,包括国产的达梦、OpenGuass、OceanBase、TiDB等,还有非关系型MongoDB、Redis等,快来试试吧! 🔥 官网:https://chat2db-ai.com/ 🔥 邀请码:622888 邀请码介绍:https://docs.chat2db-ai.com/docs/settings/i…

基于Java的全栈入门学习路线

Java全栈JavaSE数据库前端JavaWebSSM框架Linux学完以上可独立开发,下面是微服务协同开发 SpringBootSpringCloudHadoop