【题解】洛谷 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});//更新答案
}
相关推荐
wbs_scy18 分钟前
C++:unordered_map/unordered_set 使用指南(差异、性能与场景选择)
开发语言·c++·哈希算法
余衫马22 分钟前
突破语言边界:Python 与 C/C++ 集成方案年度深度总结
c++·python·性能优化·年度技术总结
小此方31 分钟前
Re: ゼロから学ぶ C++ 入門(八)类和对象·第五篇:時間计算器
开发语言·c++
无限进步_33 分钟前
C++ Vector 全解析:从使用到深入理解
开发语言·c++·ide·windows·git·github·visual studio
Dream it possible!35 分钟前
LeetCode 面试经典 150_分治_将有序数组转换为二叉搜索树(105_108_C++_简单)(递归)
c++·leetcode·面试
Q741_14735 分钟前
C++ 栈 模拟 力扣 227. 基本计算器 II 题解 每日一题
c++·算法·leetcode·模拟
徐新帅38 分钟前
CSP 二进制与小数进制转换专题及答案解析
c++·算法
im_AMBER44 分钟前
Leetcode 88 K 和数对的最大数目
数据结构·c++·笔记·学习·算法·leetcode
兵哥工控1 小时前
MFC分组平均法数据平滑曲线实例
c++·mfc
wangnaisheng1 小时前
Intel IPP 图像处理相关函数
c++·c#·图像