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

C++ | Leetcode C++题解之第352题将数据流变为多个不想交区间

题目:

题解:

class SummaryRanges {
private:map<int, int> intervals;public:SummaryRanges() {}void addNum(int val) {// 找到 l1 最小的且满足 l1 > val 的区间 interval1 = [l1, r1]// 如果不存在这样的区间,interval1 为尾迭代器auto interval1 = intervals.upper_bound(val);// 找到 l0 最大的且满足 l0 <= val 的区间 interval0 = [l0, r0]// 在有序集合中,interval0 就是 interval1 的前一个区间// 如果不存在这样的区间,interval0 为尾迭代器auto interval0 = (interval1 == intervals.begin() ? intervals.end() : prev(interval1));if (interval0 != intervals.end() && interval0->first <= val && val <= interval0->second) {// 情况一return;}else {bool left_aside = (interval0 != intervals.end() && interval0->second + 1 == val);bool right_aside = (interval1 != intervals.end() && interval1->first - 1 == val);if (left_aside && right_aside) {// 情况四int left = interval0->first, right = interval1->second;intervals.erase(interval0);intervals.erase(interval1);intervals.emplace(left, right);}else if (left_aside) {// 情况二++interval0->second;}else if (right_aside) {// 情况三int right = interval1->second;intervals.erase(interval1);intervals.emplace(val, right);}else {// 情况五intervals.emplace(val, val);}}}vector<vector<int>> getIntervals() {vector<vector<int>> ans;for (const auto& [left, right]: intervals) {ans.push_back({left, right});}return ans;}
};

http://www.mrgr.cn/news/9182.html

相关文章:

  • 使用miniconda构建数据科学环境
  • [Linux][软件]CentOS 系统部署 RabbitMQ
  • AI可预测地震,科技的“预知未来”?
  • 虚拟机桥接模式下设置静态IP
  • react redux异步请求
  • Python计算机视觉 第3章-图像到图像的映射
  • 春游c++
  • Web3链上聚合器声呐已全球上线,开启区块链数据洞察新时代
  • HTML实现俄罗斯方块
  • 每天五分钟深度学习:从数学角度分析逻辑回归算法损失函数的来源
  • Python爬虫—常用的网络爬虫工具推荐
  • 英伟达与联发科合作生产支持G-SYNC完整功能的显示器 不需要英伟达专有模块
  • 【AI趋势9】开源普惠
  • GCB | 植物多样性影响生态系统多功能性对多种全球变化因子的响应
  • springboot系列教程(三十二):SpringBoot 教程之处理异步请求
  • 南京理工大学MOOC程序设计基础第5章测试答案解析
  • 大数据技术之Flume 拓扑结构(4)
  • 【18】逃逸分析
  • 电路笔记(PCB):数字滤波电路的拉普拉斯变换与零极点分析
  • TON链上游戏项目开发基本要求及模式创建与海外宣发策略