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 12:22:44

Excalidraw + GPU算力加速:实现AI绘图实时响应

Excalidraw GPU算力加速&#xff1a;实现AI绘图实时响应 在远程协作日益成为常态的今天&#xff0c;团队对可视化工具的要求早已不再局限于“能画图”。无论是技术架构讨论、产品原型设计&#xff0c;还是敏捷会议中的即兴草图&#xff0c;人们期待的是一个既直观又智能、既能…

作者头像 李华
网站建设 2026/6/10 12:19:00

Excalidraw如何应对极端网络延迟?乐观更新策略

Excalidraw如何应对极端网络延迟&#xff1f;乐观更新策略 在跨时区协作成为常态的今天&#xff0c;一个身处新加坡的产品经理和一位位于柏林的工程师可能正在同一个虚拟白板上勾勒产品原型。但当他们的操作信号需要跨越半个地球&#xff0c;在服务器之间来回穿梭时&#xff0c…

作者头像 李华
网站建设 2026/6/10 12:28:00

Excalidraw新增模板分类筛选器,查找更高效

Excalidraw新增模板分类筛选器&#xff0c;查找更高效 在远程协作成为常态的今天&#xff0c;一个高效的可视化工具往往能决定团队沟通的质量。Excalidraw 正是这样一款“轻得恰到好处”的手绘风格白板工具——无需登录、开箱即用、实时同步&#xff0c;还能导出为静态图分享。…

作者头像 李华
网站建设 2026/6/10 12:24:16

Excalidraw新增模板热度排行榜,发现热门内容

Excalidraw 模板热度榜&#xff1a;如何用数据驱动设计协作 在今天这个信息爆炸的时代&#xff0c;我们不缺工具&#xff0c;也不缺内容——真正稀缺的是“发现优质内容”的效率。尤其是在技术团队频繁使用架构图、流程图和原型草稿的场景下&#xff0c;一张设计得当的模板往往…

作者头像 李华
网站建设 2026/6/10 3:13:38

Excalidraw能否用于电影分镜脚本绘制?正在探索

Excalidraw能否用于电影分镜脚本绘制&#xff1f;正在探索 在独立电影和短片创作日益活跃的今天&#xff0c;导演们常常面临一个现实困境&#xff1a;如何用有限的时间与资源&#xff0c;快速将剧本中的文字场景转化为可沟通、可迭代的视觉语言&#xff1f;传统分镜依赖手绘或专…

作者头像 李华
网站建设 2026/6/10 12:23:06

5、Windows XP网络连接、文件操作及压缩指南

Windows XP网络连接、文件操作及压缩指南 1. 创建网络连接 创建网络连接时,在“完成网络连接向导”对话框中,你需要在提供的文本框中输入新网络连接的描述性名称。若想在Windows桌面上添加该连接的快捷方式,可点击“将此连接的快捷方式添加到桌面”复选框。完成这些设置后,…

作者头像 李华