【c++】【leetcode128】最长连续序列(含set用法)

leetcode 最长连续序列
在这里插入图片描述

解题思路

  • 用哈希表存储所有的数
  • 遍历哈希表
  • 如果num-1在哈希表中,说明该元素不是根,忽略,如果num-1不在哈希表中,该元素为根,查找该元素的最长序列
    在这里插入图片描述

关键在于如果避免重复查找

时间复杂度分析:
在这里插入图片描述

代码

class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        if(nums.empty())return 0;
        //用集合set存储所有的数
        unordered_set<int> s;
        for(int &num : nums) {
            s.insert(num);
        }
        int ans = 1;
        for(const int &num : s){
            //如果num-1在集合中,说明不是根
            if(s.find(num-1) != s.end())continue;
            else {
                int temp = 0;
                while(temp < s.size()){
                    ++temp;
                    //找到某一个不连续的为止
                    if(s.find(num + temp) == s.end())break;
                }
                ans = max(ans,temp);
            }
        }

        return ans;
    }
};

备注

  • unordered_setset的区别
  • set基于红黑树实现,红黑树具有自动排序的功能,因此map内部所有的数据,在任何时候,都是有序的。
  • unordered_set基于哈希表,数据插入和查找的时间复杂度很低,几乎是常数时间,而代价是消耗比较多的内存,无自动排序功能。底层实现上,使用一个下标范围比较大的数组来存储元素,形成很多的桶,利用hash函数对key进行映射到不同区域进行保存

unordered_set常用接口
在这里插入图片描述
为什么无法用int去遍历unordered_set,而要用const int
c++const关键字
在这里插入图片描述
for(const int &num : s) //用引用传递,哈希表中的key不能修改,所以这里不可以直接int &num,而也要用const关键字
for(int num : s) //不用引用传递,值传递不会报错

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值