【题解】洛谷 P9658 Laser Trap

题解-P9658 Laser Trap

题目传送门

题意简述

题面是英文的,还没翻译,就讲一讲吧。

n n n 个激光发射器,两两之间产生激光束,将平面分为若干区域。

问至少删去多少个发射器,可以使得原点与外侧区域联通。

多组数据,数据范围: n ≤ 1 0 6 n\le10^6 n≤106, ∑ n ≤ 1 0 6 \sum n\le10^6 ∑n≤106


Solution \textit{Solution} Solution

前置知识
  • 叉积
  • 极角排序
  • 化环为链
  • 双指针
具体解法
  1. 将发射器围成的环化环为链
  2. 将发射器进行极角排序
  3. 使用双指针算法找最小删除量,每次得到两个指针就更新答案

瓶颈在于极角排序,达到 O ( n log ⁡ n ) O(n\log n) O(nlogn) 的复杂度,能通过本题。

  • 注意化环为链时开两倍数组

AC code

洛谷评测机:712 m s / 808.00 K B 712ms/808.00KB 712ms/808.00KB

核心代码:

cpp 复制代码
if (n<3){//特判,若n<3,易证明不需要删除
    cout<<0<<'\n';
    continue;
}
sort(a+1,a+n+1);//极角排序
for (int i=1;i<=n;i++)//化环为链
    a[i+n]=a[i];
for (int i=1,cnt=1;i<=n;i++){//双指针
    while (cnt+1<n+i&&s(a[i],a[cnt+1])>=0)
        cnt++;
    ans=min({ans,cnt-i+1,n-cnt+i-1});//更新答案
}
相关推荐
智者知已应修善业2 分钟前
【输入矩阵将其按副对角线交换后输出】2024-11-27
c语言·c++·经验分享·笔记·线性代数·算法·矩阵
阿i索3 分钟前
【蓝桥杯备赛Day3】——STL
开发语言·c++
17(无规则自律)7 分钟前
C++ 链表修炼指南
数据结构·c++·算法·leetcode·链表
闻缺陷则喜何志丹9 分钟前
【字典树 回溯】P7210 [COCI 2020/2021 #3] Vlak|普及+
c++·算法·字典树·回溯·洛谷
Vect__9 分钟前
深刻理解C++STL库常见容器功能和底层
开发语言·c++
夏玉林的学习之路10 分钟前
委托构造和using关键字
开发语言·c++·算法
历程里程碑13 分钟前
Linux 46 HTTPS(协议原理)安全通信全流程解析
linux·网络·c++·网络协议·http·https·排序算法
Yupureki21 分钟前
《C++实战项目-高并发内存池》2.ObjectPool构造
linux·服务器·c语言·开发语言·jvm·c++
格林威24 分钟前
工业相机图像高速存储(C++版):内存映射文件(MMF)零拷贝方案,附堡盟 (Baumer) 相机实战代码!
开发语言·c++·人工智能·数码相机·计算机视觉·视觉检测·工业相机
xiaoliuliu1234527 分钟前
CentOS 7 安装 gcc-c++-4.8.5-44.el7.x86_64.rpm 详细步骤(含依赖解决)
linux·c++·centos