【题解】洛谷 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});//更新答案
}
相关推荐
ZPC821040 分钟前
规划后的轨迹,如何发给 moveit_servo 执行
c++·人工智能·算法·3d
杜子不疼.41 分钟前
【C++ 在线五子棋对战】 - 工具类模块实现
开发语言·c++
橙色阳光五月天1 小时前
Qt C++项目的dump文件分析
开发语言·c++·qt
SoveTingღ1 小时前
【问题解析】Socket已经关闭了,但是端口还处于listening状态?
linux·服务器·c++·qt·socket
计算机安禾1 小时前
【c++面向对象编程】第9篇:友元(friend):破坏封装的“特权”——真的有害吗?
java·c++·log4j
William_wL_2 小时前
【C++】priority_queue(优先级队列)的使用和实现
c++
代码中介商2 小时前
C++ STL入门:vector与字符串流详解
开发语言·c++
fqbqrr2 小时前
2605C++,C++类的继承1
c++
王老师青少年编程2 小时前
csp信奥赛C++高频考点专项训练之字符串 --【字符串排序】:[NOIP 1998 提高组] 拼数
c++·字符串·csp·高频考点·信奥赛·拼数·字符串排序
草莓熊Lotso2 小时前
【Linux网络】从 0 到 1 实现高性能 UDP 聊天室:深入拆解 Linux 网络编程与线程池架构
linux·运维·服务器·网络·数据库·c++·udp