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
    }
}
相关推荐
jerryinwuhan27 分钟前
SVM案例分析
算法·机器学习·支持向量机
高山上有一只小老虎35 分钟前
购物消费打折
java·算法
郝学胜-神的一滴1 小时前
计算机图形中的法线矩阵:深入理解与应用
开发语言·程序人生·线性代数·算法·机器学习·矩阵·个人开发
m0_591338911 小时前
day8鹏哥C语言--函数
c语言·开发语言·算法
_OP_CHEN1 小时前
算法基础篇:(二)基础算法之高精度:突破数据极限
算法·acm·算法竞赛·高精度算法·oj题
一只老丸1 小时前
HOT100题打卡第30天——技巧
算法
西岭千秋雪_1 小时前
Zookeeper数据结构
java·数据结构·分布式·zookeeper
Bi_BIT1 小时前
代码随想录训练营打卡Day38| 动态规划part06
算法·动态规划
手握风云-2 小时前
回溯剪枝的“减法艺术”:化解超时危机的 “救命稻草”(三)
算法·剪枝
元亓亓亓2 小时前
LeetCode热题100--46. 全排列--中等
算法·leetcode·职场和发展