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

最长连续序列(每天刷力扣hot100系列)

目录

题目介绍:

哈希表法:

复杂度分析:

思路分析:

unordered_set 和 unordered_map的比较:

1. 核心区别

2. 使用场景

3. 在本题中的选择

4. 性能对比

5. 成员函数差异

unordered_table.begin()函数是返回的键还是值,unordered_set.begin()函数返回的又是什么呢?

1. unordered_map 的 begin()

2. unordered_set 的 begin()

关键区别


题目介绍

哈希表法:

#include <unordered_set>
#include <algorithm> // for max()class Solution {
public:int longestConsecutive(vector<int>& nums) {if (nums.empty()) return 0; // 处理空数组unordered_set<int> numSet(nums.begin(), nums.end()); // 存储所有数字int maxLen = 0;for (int num : numSet) {// 只处理序列起点(num-1不在集合中)if (numSet.find(num - 1) == numSet.end()) {int currentNum = num;int currentLen = 1;// 扩展连续序列while (numSet.find(currentNum + 1) != numSet.end()) {currentNum++;currentLen++;}maxLen = std::max(maxLen, currentLen); // 更新最大长度}}return maxLen;}
};

复杂度分析:

时间复杂度:O(n),其中 n 为数组的长度。具体分析已在上面正文中给出。

空间复杂度:O(n)。哈希表存储数组中所有的数需要 O(n) 的空间。

思路分析:

这题的思路就是先用哈希表unordered_set装初始nums数组,不需要索引所以用unordered_set而不是unordered_table。

首先遍历哈希表

1.进入条件是必须所在num-1的位置不是连续

2.这时候currentnum和currentlen初始化,currentnum指向num这个数,currentlen为1

3.然后while循环用来计算出在这之后有多少连续的整数

4.如果下一个数字不再连续了,则记录更新maxlen,接着下一轮的循环

5.如果num-1都是连续的,则直接下一轮,直到num-1断了重新初始化(即第2步)

最后返回manlen值。

unordered_set 和 unordered_map的比较:

unordered_set 和 unordered_map是 C++ STL 中的两种哈希容器

1. 核心区别

特性unordered_setunordered_map
存储内容仅存储键(key)存储键值对(key-value pairs)
用途快速判断元素是否存在(去重、集合操作)通过键快速查找/访问关联的值(字典)
元素访问直接通过键访问通过键访问对应的值(map[key]
内存占用更低(仅存储键)更高(需存储键和值)
是否允许重复键不允许(自动去重)不允许重复键(但值可重复)

2. 使用场景

  • unordered_set

    • 检测元素是否存在(如“是否包含数字 5”)。

    • 去重(如统计唯一元素个数)。

    • 集合运算(并集、交集等)。

    示例:

    unordered_set<int> s = {1, 2, 3};
    if (s.find(2) != s.end()) { /* 2存在 */ }
  • unordered_map

    • 建立键到值的映射(如“学生ID到成绩”)。

    • 需要记录额外信息(如数字的出现次数)。

    示例:

    unordered_map<int, string> m = {{1, "Alice"}, {2, "Bob"}};
    cout << m[1]; // 输出 "Alice"

3. 在本题中的选择

  • 为什么用 unordered_set
    您只需要判断数字是否存在,无需存储额外信息(如索引)。unordered_set 更节省内存且语义更直接。

    错误用法(原代码):

    unordered_map<int, int> hashtable; // 存储了无用的索引
    hashtable[nums[i]] = i; // 值(i)未被使用

    正确用法:

    unordered_set<int> numSet(nums.begin(), nums.end());
    if (numSet.find(5) != numSet.end()) { /* 5存在 */ }

4. 性能对比

  • 插入/查找时间复杂度:两者均为平均 O(1)(最坏 O(n),哈希冲突时)。

  • 空间效率unordered_set 更优(无需存储值)。


5. 成员函数差异

操作unordered_setunordered_map
插入元素insert(key)insert({key, value})
访问元素只能通过迭代器遍历map[key] 或 map.at(key)
删除元素erase(key)erase(key)

unordered_table.begin()函数是返回的键还是值,unordered_set.begin()函数返回的又是什么呢?

在 C++ 的 unordered_map 和 unordered_set 中,begin() 函数返回的是 迭代器(iterator),但它们的解引用行为不同,具体取决于容器类型:


1. unordered_map 的 begin()

  • 返回内容:返回指向第一个键值对(std::pair<const Key, Value>)的迭代器。

  • 访问键和值

    • :用 it->first 或 (*it).first

    • :用 it->second 或 (*it).second

  • 示例

    unordered_map<int, string> m = {{1, "Alice"}, {2, "Bob"}};
    auto it = m.begin();
    cout << it->first;  // 输出键:1
    cout << it->second; // 输出值:"Alice"

2. unordered_set 的 begin()

  • 返回内容:返回指向第一个元素(键本身)的迭代器。

  • 访问元素:直接解引用迭代器(*it)。

  • 示例

    unordered_set<int> s = {1, 2, 3};
    auto it = s.begin();
    cout << *it; // 输出元素:1(键本身)

关键区别

容器begin() 返回的迭代器解引用结果访问方式
unordered_mapstd::pair<const Key, Value>it->first(键)
it->second(值)
unordered_set直接是键(Key*it

求三连~~~

http://www.lryc.cn/news/611342.html

相关文章:

  • python学智能算法(三十三)|SVM-构建软边界拉格朗日方程
  • 利用 Radius Resource Types 扩展平台工程能力
  • avue---upload 图片上传
  • Vue3核心语法进阶(Props)
  • 从汇编角度揭秘C++构造函数(1)
  • 【Lua】题目小练8
  • 超越注意力机制
  • Augmodo AI:零售门店智能货架管理平台
  • 8月5号打卡
  • Java: jwt 入门介绍(Introduction to JSON Web Tokens)
  • ENS-317 Modbus TCP / 通用模式网关
  • Shader开发(七)创建第一个Shader项目
  • 完整设计 之2: 变形金刚机器人Transformer
  • 最优化中常见的优化理论
  • Guava 与 Caffeine 本地缓存系统详解
  • Windows 11 使用Windows Hello使用人脸识别登录失败,重新录入人脸识别输入PIN后报Windows Hello安装程序白屏无响应的问题解决
  • nodejs 编码初体验
  • 艺术性与真实感并存:FLUX.1 Krea [dev] 开源模型速览
  • muc中的电压调节和电源控制回路?
  • 网络相关(AI回答)
  • Linux的NFS与Autofs配置指南
  • linux定时器管理 timer_*系统调用及示例
  • table行内--图片预览--image
  • 并发编程的三要素是什么
  • Claude Code实战体验:AI智能编程助手如何重塑开发工作流?
  • 鸿蒙开发--web组件
  • Spring之【详解FactoryBean】
  • 深度学习-卷积神经网络CNN-填充与步幅
  • 27-数据仓库与Apache Hive-2
  • 二维树状数组