力扣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)

相关推荐
ghie90903 分钟前
GPS抗干扰算法MATLAB实现
开发语言·算法·matlab
格林威6 分钟前
基于轮廓特征的工件分类识别:实现无模板快速分拣的 8 个核心算法,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·目标跟踪·分类·数据挖掘
Jasmine_llq7 分钟前
《UVA11181 条件概率 Probability|Given》
数据结构·算法·深度优先搜索(dfs)·剪枝(可行性剪枝)·组合枚举(递归暴力枚举)·条件概率统计与归一化
老鼠只爱大米12 分钟前
LeetCode算法题详解 560:和为K的子数组
算法·leetcode·前缀和·哈希表·子数组求和·subarraysum
MM_MS14 分钟前
Halcon小案例--->路由器散热口个数(两种方法)
人工智能·算法·目标检测·计算机视觉·视觉检测·智能路由器·视觉
小杨同学4914 分钟前
C 语言实战:超市水果结算系统(深度解析与优化)
后端·算法·设计
码农水水41 分钟前
中国电网Java面试被问:流批一体架构的实现和状态管理
java·c语言·开发语言·面试·职场和发展·架构·kafka
a3158238061 小时前
大语言模型应用开发技术要求
算法·大语言模型·应用开发
倦王1 小时前
力扣日刷26112
算法·leetcode·职场和发展
liu****1 小时前
能源之星案例
人工智能·python·算法·机器学习·能源