当前位置: 首页 > news >正文

差分+扫描线|

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]++ 把次数加回去。

http://www.cnnetsun.cn/news/176186.html

相关文章:

  • Excalidraw自定义组件库搭建方法论
  • 30、进程间通信:命名管道与邮件槽的深入解析
  • Excalidraw助力技术文档可视化:提升沟通效率300%
  • Excalidraw绘图支持嵌入音频备注,多维信息承载
  • 15、利用Media Player畅享音乐与影视世界
  • Excalidraw实战:绘制AI模型训练流水线架构图
  • Excalidraw镜像提供专属技术支持通道,响应迅速
  • Excalidraw支持导出为Latex格式,学术写作福音
  • Excalidraw镜像提供用量统计报表,便于成本控制
  • Excalidraw支持RTL语言布局,拓展中东市场
  • Excalidraw支持外部数据源接入,打造动态仪表盘
  • Excalidraw新增自动布局功能,节省手动排版时间
  • 35、PowerShell 基础操作符及语句详解
  • 19、Windows 服务安全深度解析与防护策略
  • 31、Windows Server 2008 安全配置与管理全解析
  • 33、补丁管理全攻略
  • 32、PowerShell 文件处理全解析
  • 40、使用 COM 自动化 Windows 及相关应用
  • 50、PowerShell 管理脚本与操作示例详解
  • 78、计算机硬件、性能与网络问题排查及搭建指南
  • 基于Java+SpringBoot+SSM电脑商城系统(源码+LW+调试文档+讲解等)/电脑商城平台/电脑购物系统/计算机商城系统/在线电脑商城/电脑销售系统/电脑商城软件
  • Excalidraw助力技术布道师打造精彩演讲视觉素材
  • Excalidraw打造沉浸式头脑风暴环境,激发团队创造力
  • 一种新型几何形状被发送到国际空间站,很可能是3D打印的
  • Excalidraw绘图元素库持续更新,满足更多业务需求
  • Excalidraw如何保护用户隐私?数据存储策略说明
  • 用Excalidraw做技术分享?这些技巧让你事半功倍
  • 用自然语言生成图表?Excalidraw AI功能实测报告
  • Excalidraw + GPU算力 极速AI图形生成体验
  • 信息学奥赛一本通 1618:越狱 | 洛谷 P3197 [HNOI2008] 越狱