128. 最长连续序列

思路:

剪枝: 判断当前元素是否有前一位元素(是否起始点)

哈希: 插入哈希集合,查询元素

总体: 起始点,从头向前,更新最高长度

语法注意:

(1)HashSetcontains 方法期望引用 &T 而不是值类型 T,主要是为了避免不必要的内存拷贝和移动,同时遵循 Rust 的所有权和借用规则

(2)在 for num in & HashSet 比在 for &num in &Vec 中遍历 快 20 倍。

  • 遍历对象不同HashSet 遍历(for num in &set)避免了重复元素和解引用操作,而 Vec 遍历(for &num in &nums)可能包含重复元素和解引用开销。

  • 性能差异HashSet 提供更高效的查找和避免重复计算,因此在大数据集上,遍历 HashSet 通常更快。

代码:

复制代码
use std::collections::*;

impl Solution {
    pub fn longest_consecutive(nums: Vec<i32>) -> i32 {
        let mut set = HashSet::new();
        for &num in &nums {
            set.insert(num);
        }
        let mut longest = 0;
        for num in &set {
            if set.contains(&(*num - 1)) {continue;}
            let mut temp = *num + 1;
            while set.contains(&(temp)) {
                temp += 1;
            }
            longest = longest.max(temp - *num);
            
        }
        longest
    }
}
相关推荐
自然语6 分钟前
人工智能之数字生命-学习的过程
数据结构·人工智能·深度学习·学习·算法
你好~每一天14 分钟前
从传统行业到AI入门:我的CAIE Level I学习体验与思考
大数据·数据结构·人工智能·学习·jupyter·idea
Yuezero_17 分钟前
Research Intern面试(一)——手敲LLM快速复习
pytorch·深度学习·算法
wyiyiyi28 分钟前
【数据结构+算法】非递归遍历二叉树的理解
大数据·数据结构·笔记·算法·leetcode·数据分析
fashion 道格32 分钟前
从地图导航到数据结构:解锁带权有向图的邻接链表奥秘
c语言·数据结构·链表
2401_8933266235 分钟前
力扣1971.寻找图中是否存在路径
算法·leetcode·职场和发展
专注API从业者38 分钟前
构建分布式京东商品数据采集器:基于微服务的架构设计与实现
数据结构·数据库·分布式·微服务·架构
zs宝来了44 分钟前
HOT100-技巧类型题
数据结构·算法
Ayanami_Reii44 分钟前
进阶数据结构-FenwickTree
数据结构·算法·树状数组·fenwick tree
爪哇部落算法小助手1 小时前
每日两题day59
数据结构·c++·算法