news 2026/1/9 9:14:02

LC.981 | 基于时间的键值存储 | 哈希 | upper_bound快速定位

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LC.981 | 基于时间的键值存储 | 哈希 | upper_bound快速定位

输入:

  • set(key, value, timestamp)
  • get(key, timestamp)

要求:

  • 同一个key在不同timestamp可以存多次
  • get需要返回:timestamp_prev <= timestamp的最大那次对应的 value
  • 如果不存在返回空串""

输出:

  • set:无返回
  • getstring

思路:

这题的核心就是:对每个 key,把 (timestamp -> value) 存起来,并且能快速找“<= timestamp 的最大时间点”。

数据结构选择:

  • 外层:unordered_map<string, ...>通过 key 快速定位一组记录
  • 内层:map<int, string>自动按 timestamp 升序存放,支持二分相关操作

get(key, timestamp)怎么找?

  • upper_bound(timestamp):它返回第一个 > timestamp 的迭代器
  • 那么“<= timestamp 的最大值”就是它的前一个位置
  • 特判两种情况:
    1. 这个 key 压根不存在 ->""
    2. upper_bound指向 begin,说明所有 timestamp 都 > 目标 ->""
    3. 否则--it返回答案

复杂度:

  • 时间复杂度:
    • set:O(log M)
    • get:O(log M)
    • 其中 M 是某个 key 下存了多少条记录
  • 空间复杂度:O(总记录数)

classTimeMap{unordered_map<string,map<int,string>>m;public:TimeMap(){}voidset(string key,string value,inttimestamp){m[key][timestamp]=value;}stringget(string key,inttimestamp){if(m.find(key)==m.end())return"";map<int,string>&time_m=m[key];autoit=time_m.upper_bound(timestamp);// first > timestampif(it==time_m.begin())return"";// all > timestamp--it;// last <= timestampreturnit->second;}};
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/6 12:36:06

《AI应用架构师眼中的企业AI价值链优化创新之道》

AI应用架构师眼中的企业AI价值链优化创新之道——从需求到落地的全流程增效策略 摘要 在企业AI转型的浪潮中&#xff0c;**“重模型、轻流程”**的传统思路往往导致项目陷入“需求对齐难、数据质量差、模型落地慢、ROI不明显”的困境。作为AI应用架构师&#xff0c;我深刻意识到…

作者头像 李华
网站建设 2026/1/7 13:18:34

深度学习毕设选题推荐:基于卷积网络结构的火灾检测系统实现

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/1/7 10:39:19

9个降AI率工具推荐!继续教育人群高效避坑指南

9个降AI率工具推荐&#xff01;继续教育人群高效避坑指南 AI降重工具&#xff0c;让论文更“自然” 在继续教育的学术道路上&#xff0c;越来越多的学习者开始关注论文的AIGC率问题。随着AI技术的普及&#xff0c;许多学生在撰写论文时会借助AI辅助工具&#xff0c;但这也带来了…

作者头像 李华
网站建设 2026/1/9 8:07:46

强烈安利9个AI论文软件,专科生毕业论文必备!

强烈安利9个AI论文软件&#xff0c;专科生毕业论文必备&#xff01; AI 工具正在改变论文写作的未来 在当今这个科技飞速发展的时代&#xff0c;AI 工具已经逐渐渗透到各个领域&#xff0c;其中论文写作也迎来了前所未有的变革。对于专科生而言&#xff0c;毕业论文往往是一个巨…

作者头像 李华
网站建设 2026/1/6 11:19:48

环境仿真软件:EcoPath with Ecosim_(3).EcoPath模型构建

EcoPath模型构建 模型构建概述 EcoPath with Ecosim (EwE) 是一个用于生态系统建模和仿真的强大工具。通过构建EcoPath模型&#xff0c;用户可以创建一个生态系统的静态快照&#xff0c;从而为后续的动态模拟提供基础。EcoPath模型的构建主要包括以下几个步骤&#xff1a;数据…

作者头像 李华
网站建设 2026/1/8 5:12:44

【毕业设计】基于卷积网络结构的火灾检测系统实现

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华