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

苍山网站建设网站设计分享

苍山网站建设,网站设计分享,wordpress古文主题,1号店网站模板下载*注&#xff1a;代码和题解思路来源于灵茶山艾府&#xff0c;因为我之前未接触过vector<pair<>>与map的联合使用才写的笔记 链接&#xff1a;灵茶山艾府题解 核心思路&#xff1a;建立 unordered_map<int, vector<pair<int, int>>> history; …

*注:代码和题解思路来源于灵茶山艾府,因为我之前未接触过vector<pair<>>与map的联合使用才写的笔记  链接:灵茶山艾府题解

核心思路:建立 unordered_map<int, vector<pair<int, int>>> history;  令key为下标 vector存放不同快照引索的值,详看下文的输出

 unordered_map<int, vector<pair<int, int>>> history; 

键:int 

值:vector<pair<int, int>>

history[0] 会访问 history 中键为 0 所对应的 std::vector<std::pair<int, int>>。如果该键不存在,会自动创建一个空的 vector。



// 正确访问方式
    if (!history[0].empty()) {
        int firstValue = history[0][0].first;  10
        int secondValue = history[0][0].second;  20
}


在代码里,使用 history[0].emplace_back(10, 20); 向 history 中键为 0 对应的 vector 里"插入"了一个 std::pair<int, int> 对象,其值为 (10, 20)。

emplace_back(10, 20) 会在这个 vector 的末尾直接构造一个 std::pair<int, int> 对象,这个对象的第一个元素是 10,第二个元素是 20。

  history[0].emplace_back(10, 20);
    history[0].emplace_back(30, 40);
    history[1].emplace_back(50, 60);

unordered_map数组的状态

key=index是下标题目说的下标
Key: 0
  (10, 20)history[key][0]  history[index][0].first --10快照索引  history[index][0].second--20
  (30, 40)history[key][0]
Key: 1
  (50, 60)

代码分析:

 int j = ranges::lower_bound(h, pair(snap_id + 1, 0)) - h.begin() - 1;
                中 pair(snap_id + 1, 0)
        假设 h 中有如下元素:
std::vector<std::pair<int, int>> h = { {10, 20}, {30, 40}, {50, 60} };

若 snap_id 为 20,那么 std::pair(snap_id + 1, 0) 就是 std::pair(21, 0)。
std::ranges::lower_bound 算法会依据 std::pair 的第一个元素进行比较,找到第一个大于等于 21 的元素,也就是 (30, 40)。
在这个过程中,std::pair 的第二个元素 0 并不影响查找结果,它只是占位,保证 std::pair 类型的完整性。

class SnapshotArray {unordered_map<int,vector<pair<int, int>>> history; int c_snap_id=0;
public:SnapshotArray(int length) {}void set(int index, int val) {history[index].emplace_back(c_snap_id,val);}int snap() {return c_snap_id++;}int get(int index, int snap_id) {auto &h=history[index];int j=ranges::lower_bound(h,pair(snap_id+1,0))-h.begin()-1;return j>=0?h[j].second:0;}
};/*** Your SnapshotArray object will be instantiated and called as such:* SnapshotArray* obj = new SnapshotArray(length);* obj->set(index,val);* int param_2 = obj->snap();* int param_3 = obj->get(index,snap_id);*/

http://www.dtcms.com/a/548706.html

相关文章:

  • 一个蛇形填充n×n矩阵的算法
  • git index lockFile exists 问题
  • 一段音频/视频分离成人声与伴奏,Windows + Anaconda 快速跑通 Spleeter(离线可用)
  • RecyclerView设置边缘渐变失效
  • 网站续费模版徐州建设工程网上交易平台
  • [系统架构设计师]云原生架构
  • spec-kit深度解析:AI驱动的规范驱动开发(SDD)的架构、哲学与实践启示
  • 怎么学做网站哈尔滨十大广告公司
  • AI应用开发
  • Rust 中精确大小迭代器(ExactSizeIterator)的深度解析与实践
  • 培训/课程预约小程序开发-提升教育机构的管理效率和用户体验
  • 【Unity基础详解】(3)Unity核心类:GameObject
  • oj题 ——— 单链表oj题
  • 企业网站建设推广含义网站建设开发上线流程
  • Unity-AutoHand插件手势跟踪响应研究
  • 数据结构——三十三、Dijkstra算法(王道408)
  • MQTTX:全能的 MQTT 客户端工具简化物联网开发
  • 抗体芯片技术:超越Western Blot的高通量蛋白分析方案
  • 佛山公司网站建设价格企业查询平台
  • k8s介绍+k8s部署
  • 【H5工具】一个简约高级感渐变海报H5设计工具
  • 未来之窗昭和仙君(四十五)时钟应用场景——东方仙盟筑基期
  • TTL转485电路
  • Milvus知识
  • 实战:动态线程池应对短视频转码百倍流量洪峰
  • 第一部分:一般性理論(注定的概率論)第一章引入
  • 合肥大型网站设计互联网营销师怎么做
  • 建设公众号网站评分标准细则网站的站内结构锚文本是如何做的
  • 裸金属 vs. 虚拟化 GPU 服务器:AI 训练与推理应该怎么选
  • 做网站的语言建设一下网站要求提供源码