news 2026/6/10 10:58:29

差分+扫描线|

作者头像

张小明

前端开发工程师

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/6/10 11:53:56

Excalidraw如何提升产品原型设计效率?真实案例分享

Excalidraw如何提升产品原型设计效率&#xff1f;真实案例分享 在一次跨时区的产品评审会上&#xff0c;团队争论的焦点不是功能逻辑&#xff0c;而是“这个按钮到底该放在左边还是右边”。设计师展示了精美的Figma稿&#xff0c;开发却说实现成本太高&#xff0c;产品经理则担…

作者头像 李华
网站建设 2026/6/10 9:33:39

【stm32】cmake脚本(一)

这个写了自动配置cmake环境脚本&#xff0c;可以自己改自己用的交叉编译器。 【stm32】bash自动配置buildenv自动配置编译环境_edgetx 编译-CSDN博客 平台ubuntu22.04&#xff0c;代码查看使用vscode。背景为一套可以按要求为不同stm32编译同样功能的代码。 使用了CMake缓存…

作者头像 李华
网站建设 2026/6/9 22:49:28

Excalidraw如何实现像素级精准对齐?网格系统详解

Excalidraw 如何实现像素级精准对齐&#xff1f;网格系统详解 在数字协作工具日益普及的今天&#xff0c;虚拟白板早已不再是简单的“画图板”。从技术架构设计到产品原型草图&#xff0c;团队越来越依赖像 Excalidraw 这样的开源手绘风格白板来完成高信息密度的表达。它那看似…

作者头像 李华
网站建设 2026/6/10 11:08:53

27、高级线程同步技术详解

高级线程同步技术详解 在多线程编程中,线程同步是一个至关重要的问题,它关乎着程序的正确性、稳定性和性能。本文将深入探讨高级线程同步的相关技术,包括信号量、条件变量模型、阈值屏障对象、队列对象以及多阶段管道中队列的使用等内容。 信号量与条件变量模型 在某些情…

作者头像 李华
网站建设 2026/6/10 11:17:35

35、重叠 I/O 和扩展 I/O 详解

重叠 I/O 和扩展 I/O 详解 在进行 I/O 操作时,性能和可扩展性往往是主要目标。虽然内存映射 I/O 在处理文件时非常有效,但从内存映射 I/O 错误中恢复并非易事。接下来我们详细探讨重叠 I/O 以及与之相关的内容。 重叠 I/O 概述 异步 I/O(无论是重叠还是扩展)的首要要求是…

作者头像 李华
网站建设 2026/6/10 11:17:14

Excalidraw如何实现跨浏览器兼容?主流内核测试全覆盖

Excalidraw如何实现跨浏览器兼容&#xff1f;主流内核测试全覆盖 在远程协作成为常态的今天&#xff0c;一个能在任何设备、任何浏览器上“开箱即用”的白板工具&#xff0c;几乎是每个技术团队的刚需。而当你在Chrome里画好一张架构图&#xff0c;同事却在Safari中看到错位的线…

作者头像 李华