news 2026/4/18 3:34:54

差分+扫描线|

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
差分+扫描线|

lc1851

有点像双指针的意思

class Solution {
public:
vector<int> minInterval(vector<vector<int>>& intervals, vector<int>& queries) {
int n = intervals.size(), m = queries.size();
sort(intervals.begin(), intervals.end());
using pii = pair<int, int>;
vector<pii> qs;
for (int i = 0; i < m; ++i) {
qs.emplace_back(queries[i], i);
}
sort(qs.begin(), qs.end());
vector<int> ans(m, -1);
priority_queue<pii, vector<pii>, greater<pii>> pq;
int i = 0;
for (auto& [x, j] : qs) {
while (i < n && intervals[i][0] <= x) {
int a = intervals[i][0], b = intervals[i][1];
pq.emplace(b - a + 1, b);
++i;
}
while (!pq.empty() && pq.top().second < x) {
pq.pop();
}
if (!pq.empty()) {
ans[j] = pq.top().first;
}
}
return ans;
}
};

lc1674

差分➕扫描线

差分统计数组两两配对和的不同区间所需移动次数,遍历求最小移动次数

sum:差分在“全需 2 次移动”的基准上,按区间调整真实移动次数。

class Solution {
public:
int minMoves(vector<int>& a, int l) {
int n = a.size();
vector<int> d(l * 2 + 2);
for (int i = 0; i < n / 2; ++i) {
int x = a[i], y = a[n - i - 1];
int lo = 1 + min(x, y);
int hi = l + max(x, y);
int s = x + y;
d[lo]--;
d[s]--;
d[s + 1]++;
d[hi + 1]++;

//对可抵达的结果 差分
}


int c = n,res = n;
for (int i = 2; i <= l * 2; ++i) {

//差分求和 得到可抵达点的操作数
c += d[i];
res = min(res, c);
}
return res;
}
};

1. 初始基准值 c = n

假设每个数字都要移动一次,数组长度为n

2. 差分的基准逻辑

差分数组的作用是修正这个基准值:

- 落在 [lo, sum) 区间的目标和,数对只需 1 次移动 → 总次数减 1,对应 d[lo]-- 。

- 目标和等于 sum 时,数对无需移动 → 总次数再减 1,对应 d[sum]-- 。

- 超过 sum 或 hi 后,修正失效,对应 d[sum+1]++ 和 d[hi+1]++ 把次数加回去。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 3:31:03

聊聊 C 里的进制转换、移位操作与算术转换

前言 学 C 语言时&#xff0c;总绕不开 “进制怎么转”“移位操作符怎么用”“表达式为啥这么算” 这些问题 —— 它们不算多高深&#xff0c;但都是写代码、调 Bug 的基础。 比如写个简单的位运算&#xff0c;若搞不清二进制和十进制的转换逻辑&#xff0c;很容易算错结果&a…

作者头像 李华
网站建设 2026/4/16 12:33:53

Excalidraw镜像具备弹性伸缩能力,资源利用率更高

Excalidraw 镜像的弹性伸缩实践&#xff1a;如何实现高效资源利用 在现代远程协作日益频繁的背景下&#xff0c;可视化工具早已不再是“锦上添花”&#xff0c;而是团队运转的核心组件。工程师画架构图、产品经理做原型推演、设计师进行流程梳理——这些场景几乎都绕不开一个轻…

作者头像 李华
网站建设 2026/4/18 3:20:37

Excalidraw能否用于航空航天系统设计?高可靠性验证中

Excalidraw 在航空航天系统设计中的应用潜力与边界 在某次小型卫星姿态控制系统的联合评审会上&#xff0c;来自北京的结构工程师拖动着一个手绘风格的矩形框&#xff0c;实时标注“星敏感器安装位置需避开热变形区”&#xff0c;而远在慕尼黑的飞控团队立即在其旁边添加了红色…

作者头像 李华
网站建设 2026/4/18 3:21:36

4、Windows系统文件与网络操作全指南

Windows系统文件与网络操作全指南 在Windows系统中,我们经常需要对各种文件、文件夹进行操作,同时也会涉及到网络连接等相关设置。下面将详细介绍一些常见的操作方法。 1. 访问和操作“我的视频”文件夹 在Windows XP系统中,若要访问“我的视频”文件夹,可以通过以下方式…

作者头像 李华
网站建设 2026/4/18 3:19:03

8、Windows XP 使用指南:窗口、文件管理与媒体播放

Windows XP 使用指南:窗口、文件管理与媒体播放 1. 窗口操作基础 在使用电脑时,窗口操作是基础且常用的技能。当你需要让某个窗口保持打开状态(特别是当它在后台运行打印、计算等进程),但暂时又不会直接使用其功能时,可以将该窗口最小化。而当你在做其他事情的同时,还…

作者头像 李华
网站建设 2026/4/18 3:14:57

Excalidraw新增最近编辑者标记,协作责任明确

Excalidraw 新增最近编辑者标记&#xff0c;协作责任明确 在远程协作日益成为常态的今天&#xff0c;一个看似微小的设计改动&#xff0c;往往能带来巨大的效率提升。比如&#xff1a;你正在和团队共同绘制一张复杂的系统架构图&#xff0c;突然发现某个关键模块的位置被移动了…

作者头像 李华