当前位置: 首页 > news >正文

CF333E Summer Earnings

推歌:Between Worlds

很有意思的题。

注意到题目其实就是选三个点使得两两之间欧几里得距离最小值最大,很容易就有 \(O(n^3)\) 做法。

常规方法是注意到本题时限极大,而最小值最大又是可以从大到小枚举最小值的,因此把所有的点对按照距离排序从大到小扫,每次就是对 \((i,j)\) 求是否有 \(k\) 使得 \((i,k)\)\((k,j)\) 的距离都比它大,可以很容易地用 Bitset 维护,\(O(\frac{n^3}{\omega})\) 即可通过。

但是有没有不靠 \(\omega\) 的方法呢?让我们使用一些中学学过的数学知识。

初中有一句话叫做“大角对大边”(其实就是正弦定理)而题目的问题又等价于求三角形中最短边的最大值,所以直接考虑枚举一个点 \(P\) 作为顶点。我们发现三角形的最小角一定是 \(\le \frac{\pi}{3}\) 的,如果以 \(P\) 为顶点的 \(\angle APB\ge \frac{\pi}{3}\),那么此三角形的最短边一定在 \(PA\)\(PB\) 中。

因此固定 \(A\) 后,我们要找的 \(B\) 就是使得 \(\angle APB\ge \frac{\pi}{3}\)\(PB\) 最短的点,这是一个静态区间最小值!

然后我们就可以直接做了。枚举 \(P\),将剩余的点以 \(P\) 为原点进行极角排序,ST 表预处理区间最小值,枚举 \(A\) 并快速求 \(B\)。由于每个点都会作为顶点出现所以不会有哪组最短边没扫到的情况。时间复杂度 \(O(n^2\log n)\)

感觉其实并不算数学题?只是用了基础的几何知识而已。

http://www.zskr.cn/news/10729.html

相关文章:

  • 【Jenkins】调整到实战教程
  • 职业卡点怎么破?3个月私教服务助你升级技能与面试技巧
  • OI?原来这么简单-语法算法入门篇
  • Windows使用cmd命令行中查看、修改、删除与添加环境变量
  • Rouyan:使用WPF/C#构建的基于LLM的快捷翻译小工具
  • 记录用户业务请求日志
  • CentOS6.8安装docker教程
  • K12教育 和 STEAM教育
  • 龙虎榜——20250912 - 详解
  • Avalonia 背景颜色Transparent在用户界面设计中对悬浮效果影响的总结
  • 第十四届蓝桥杯青少组C++选拔赛[2022.12.18]第二部分编程题(4、充电站) - 指南
  • 界面控件DevExpress WinForms中文教程:Data Grid - 搜索/查找面板
  • c语言之自定义memcpy
  • 国产芯片处理板卡:7-基于国产化FT-M6678+JFM7K325T的6U CPCI信号处理卡
  • css-轮播图效果
  • aspnetcore使用websocket实时更新商品信息
  • 漏洞挖掘实战:如何定制化模糊测试技术
  • css-遮罩层效果
  • css-浮动围绕文字效果
  • 基于Python+Vue开发的摄影网上预约管理系统源码+运行步骤
  • css-定位让盒子居中显示
  • 在线教育软件开发的全流程解析与优化方案
  • 浅谈云原生数据库
  • AT_abc201_f [ABC201F] Insertion Sort 题解
  • c语言动态内存分配
  • 2025.9.24——1橙
  • 完整教程:MySQL 启动日志报错: File /mysql-bin.index not found (Errcode: 13 - Permission denied)
  • Python爬虫实现大乐透历史数据抓取
  • Java实现双色球历史是否中奖查询
  • 别再混淆 PHP8.1 中纤程 Fibers 和协程 Coroutines 了 一文搞懂它们的区别