力扣100题——128题

题目

************************************************

解(哈希)

VS完整代码

cpp 复制代码
#include<iostream>
#include<vector>
#include<unordered_set>
#include<utility>
#include<algorithm>
using namespace std;
int n, num;

int longestConsecutive(vector<int>& nums) {
	//使用哈希集合去重,遍历nums,对于每一个在集合中查找其及上下连续数字
	unordered_set<int> nums_set(nums.begin(), nums.end());
	int len = 0;
	int maxlen = 0;
	for (int num : nums) {
		if (nums_set.find(num)!= nums_set.end()) {
			nums_set.erase(num);
			len = 1;

			int cur = num - 1;
			while(nums_set.find(cur) != nums_set.end()) {
				nums_set.erase(cur);
				cur--;
				len++;
			}
			cur = num + 1;
			while (nums_set.find(cur) != nums_set.end()) {
				nums_set.erase(cur);
				cur++;
				len++;
			}
			maxlen = maxlen > len ? maxlen : len;
		}
		return maxlen;
	}
}

int main() {
	vector<int> nums;
	cin >> n;
	for (int i = 0; i < n; i++) {
		cin >> num;
		nums.push_back(num);
	}
	cout << longestConsecutive(nums) << endl;
	return 0;

}

力扣代码:

cpp 复制代码
class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        // 使用哈希集合去重,遍历nums,对于每一个在集合中查找其及上下连续数字
        unordered_set<int> nums_set(nums.begin(), nums.end());
        int maxlen = 0;
        for (int num : nums) {
            if (nums_set.find(num) != nums_set.end()) {
                nums_set.erase(num);
                int len = 1;

                int cur = num - 1;
                while (nums_set.find(cur) != nums_set.end()) {
                    nums_set.erase(cur);
                    cur--;
                    len++;
                }
                cur = num + 1;
                while (nums_set.find(cur) != nums_set.end()) {
                    nums_set.erase(cur);
                    cur++;
                    len++;
                }
                maxlen = maxlen > len ? maxlen : len;
            }
        }
        return maxlen;
    }
};

通过!

复杂度分析:

用的集合unordered_set,这个集合平均的查找、删除等的时间复杂度通常看作O(1),我们遍历nums相当于O(n)。但是对于每个元素,我们只会进行一次操作,即删除(第一次访问到,第一次作为cur-1被访问到,或者cur+1被访问到)。故至多为O(n)

相关推荐
晨晖210 小时前
顺序查找:c语言
c语言·开发语言·算法
LYFlied10 小时前
【每日算法】LeetCode 64. 最小路径和(多维动态规划)
数据结构·算法·leetcode·动态规划
七禾页丫10 小时前
面试记录12 软件(c++)工程师
c++·面试·职场和发展
Salt_072810 小时前
DAY44 简单 CNN
python·深度学习·神经网络·算法·机器学习·计算机视觉·cnn
货拉拉技术10 小时前
AI拍货选车,开启拉货新体验
算法
MobotStone11 小时前
一夜蒸发1000亿美元后,Google用什么夺回AI王座
算法
Wang2012201311 小时前
RNN和LSTM对比
人工智能·算法·架构
xueyongfu11 小时前
从Diffusion到VLA pi0(π0)
人工智能·算法·stable diffusion
永远睡不够的入11 小时前
快排(非递归)和归并的实现
数据结构·算法·深度优先
cheems952711 小时前
二叉树深搜算法练习(一)
数据结构·算法