news 2026/5/1 12:41:11

差分+扫描线|

作者头像

张小明

前端开发工程师

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/29 0:08:13

Excalidraw绘图支持嵌入实时数据卡片,动态刷新

Excalidraw绘图支持嵌入实时数据卡片&#xff0c;动态刷新 在今天的远程协作环境中&#xff0c;一张静态的架构图往往刚画完就已经“过时”了。服务状态变了、负载升高了、CI/CD 流水线又失败了一次——但白板上的图形却纹丝不动。这种信息滞后不仅影响决策效率&#xff0c;更可…

作者头像 李华
网站建设 2026/4/30 8:38:12

Excalidraw性能优化建议:大文件加载不卡顿秘诀

Excalidraw性能优化建议&#xff1a;大文件加载不卡顿秘诀 在现代技术团队的日常协作中&#xff0c;一张“随手画”的架构草图&#xff0c;往往比千行文档更能快速对齐思路。Excalidraw 正是抓住了这一痛点&#xff0c;凭借其手绘风格、极简交互和开源特性&#xff0c;迅速成为…

作者头像 李华
网站建设 2026/4/30 15:05:15

Excalidraw如何防范XSS攻击?前端安全措施详解

Excalidraw如何防范XSS攻击&#xff1f;前端安全措施详解 在当今远程协作日益频繁的背景下&#xff0c;像 Excalidraw 这样的在线白板工具正被广泛用于产品设计、技术架构绘制和团队头脑风暴。它以极简的手绘风格、实时协同能力以及对AI驱动绘图的支持赢得了大量开发者与设计师…

作者头像 李华
网站建设 2026/4/24 17:05:56

Excalidraw被用于开源社区大型活动策划白板

Excalidraw&#xff1a;开源社区大型活动策划中的可视化协作新范式 在一场横跨三大洲的全球开源贡献者大会上&#xff0c;策划团队正面临典型难题&#xff1a;如何让分布在不同时区的20多名志愿者高效协同完成议程设计、资源分配与流程梳理&#xff1f;没有会议室&#xff0c;…

作者头像 李华
网站建设 2026/4/23 18:45:31

6、Windows 文件与文件夹管理全攻略

Windows 文件与文件夹管理全攻略 在日常使用计算机的过程中,文件与文件夹的管理至关重要。无论是压缩、加密文件,还是创建快捷方式、清理垃圾文件,都直接影响着我们的工作效率和数据安全。下面就为大家详细介绍 Windows 系统中文件与文件夹管理的相关操作。 压缩文件夹相关…

作者头像 李华
网站建设 2026/4/26 0:45:41

10、Windows Media Player与打印功能全解析

Windows Media Player与打印功能全解析 在日常使用电脑的过程中,多媒体播放和文件打印是非常常见的操作。下面将详细介绍Windows Media Player的使用方法以及打印相关的操作。 1. Windows Media Player视频播放设置 在“正在播放”模式下观看视频时,可以进行以下设置: -…

作者头像 李华