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
    }
}
相关推荐
wuhen_n6 小时前
LeetCode -- 1:两数之和(简单)
javascript·算法·leetcode·职场和发展
林shir7 小时前
Java基础1.7-数组
java·算法
Jeremy爱编码8 小时前
leetcode课程表
算法·leetcode·职场和发展
甄心爱学习8 小时前
SVD求解最小二乘(手写推导)
线性代数·算法·svd
努力学算法的蒟蒻8 小时前
day46(12.27)——leetcode面试经典150
算法·leetcode·面试
Blockbuater_drug8 小时前
InChIKey: 分子的“化学身份证”,从哈希原理到全球监管合规(2025)
算法·哈希算法·inchikey·rdkit·分子表达·化学信息学
橙汁味的风9 小时前
2EM算法详解
人工智能·算法·机器学习
维构lbs智能定位9 小时前
北斗卫星导航定位从核心框架到定位流程详解(一)
算法·北斗卫星导航定位系统
byzh_rc9 小时前
[算法设计与分析-从入门到入土] 动态规划
算法·动态规划
Halo_tjn9 小时前
Java List集合知识点
java·开发语言·windows·算法·list