首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

最长连续序列

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。 请你设计并实现时间复杂度为 O(n) 的算法解决此问题。...示例 1: 输入:nums = [100,4,200,1,3,2] 输出:4 解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。...示例 2: 输入:nums = [0,3,7,2,5,8,4,6,0,1] 输出:9 我们考虑枚举数组中的每个数 ,考虑以其为起点,不断尝试匹配 是否存在,假设最长匹配到了 ,那么以 为起点的最长连续序列即为...但仔细分析这个过程,我们会发现其中执行了很多不必要的枚举,如果已知有一个 的连续序列,而我们却重新从 或者是 处开始尝试匹配,那么得到的结果肯定不会优于枚举 为起点的答案,因此我们在外层循环的时候碰到这种情况跳过即可...外层循环需要 的时间复杂度,只有当一个数是连续序列的第一个数的情况下才会进入内层循环,然后在内层循环中匹配连续序列中的数,因此数组中的每个数只会进入内层循环一次。

12820
您找到你想要的搜索结果了吗?
是的
没有找到

最长连续序列

# 题目链接 # 贪心算法 最主要的思路是将所有数存入set集合,然后再遍历数组,如果一个数不是当前连续序列的第一个,则不计数,当它是序列中第一个数才统计其所在连续序列的长度。...这样做正确是因为如果一个数不是一个连续序列的开头,那么从它开始往后查找总拿不到最长的连续序列的长度,我们贪心的用一个连续序列的开始元素去计算其长度,能够将时间均摊到O(1)O(1)O(1)。...,现在才统计其所在连续序列长度 // 在整个for循环中,此while循环总共走了n次,因为数组中的数只属于一个连续序列 // 而我们每次只从连续序列的开始往后走...map.put(num, -1); // 更新左端点开始连续序列的长度 map.put(num-lLen..., curLen); // 更新右端点结尾连续序列的长度 map.put(num+rLen, curLen); }

30520

最长连续序列(leetcode 128)

1.问题描述 给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。 请你设计并实现时间复杂度为 O(n) 的算法解决此问题。...示例 1: 输入:nums = [100,4,200,1,3,2] 输出:4 解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。...那么,每当发生了“断点”,如果当前连续序列长度大于 result 则更新 result 值,result 表示最长连续序列的长度。...外层循环需要 O(n) 的时间复杂度,只有当一个数是连续序列的第一个数的情况下才会进入内层循环,然后在内层循环中匹配连续序列中的数,因此数组中的每个数只会进入内层循环一次。...最长连续序列 - leetcode

13410

最大连续序列

概要 题目描述 给定K个整数的序列{ N1, N2, …, NK },其任意连续序列可表示为{ Ni, Ni+1, …, Nj },其中 1 <= i <= j <= K。...最大连续序列是所有连续序列中元素和最大的一个,例如给定序列{ -2, 11, -4, 13, -5, -2 },其最大连续序列为{ 11, -4, 13 },最大和为20。...输出描述: 对每个测试用例,在1行里输出最大和、最大连续序列的第一个和最后一个元素,中间用空格分隔。如果最大连续序列不唯一,则输出序号i和j最小的那个(如输入样例的第2、3组)。...-2 0 输出 20 11 13 10 1 4 10 3 5 10 10 10 0 -1 -2 0 0 0 ---- 思路 best,best_tmp分别存储最大和和当前的连续序列和...bestL,bestL_tmp分别存储左边第一个和当前的连续序列左边第一个 bestR,bestR_tmp分别存储最后一个和和当前的连续序列最后一个 best小于0时把重新best,bestL

75110

最长连续序列(leetcode 128)

1.问题描述 给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。 请你设计并实现时间复杂度为 O(n) 的算法解决此问题。...示例 1: 输入:nums = [100,4,200,1,3,2] 输出:4 解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。...那么,每当发生了“断点”,如果当前连续序列长度大于 result 则更新 result 值,result 表示最长连续序列的长度。...外层循环需要 O(n) 的时间复杂度,只有当一个数是连续序列的第一个数的情况下才会进入内层循环,然后在内层循环中匹配连续序列中的数,因此数组中的每个数只会进入内层循环一次。...最长连续序列 - leetcode

17710

最长连续递增子序列问题

最长递增子序列问题: 给定一个长度为N的数组,给定一个长度为N的数组,找出一个最长的单调自增子序列(不一定连续,但是顺序不能乱)。...例如:给定一个长度为6的数组A{5, 6, 7, 1, 2,8},则其最长的单调递增子序列为{5,6,7,8},长度为4。...遍历完整个数组之后,得到整个dp数组中最大的那个dpj便是最长递增子序列的长度。...因为既然可以以5来往后找最长连续递增子序列,那为什么不拿1来找呢?所以这就是算法的核心 [13vcsu2wul.png] 5)遍历到2,同样由于22最左边的数,为6,替换,理由同上。...[3fdgi4oo67.png] 算法结束,最长连续递增子序列就是此时tempArr数组中的长度,为4.

87730

SQL 获取定长连续序列

要求:从 savior 表中获取状态为 0 的 id,并且这些 id 能够组成长度为 3 的连续序列。 比如,id = 3、4、5 的数据,它们的状态为 0,且它们构成的序列长度正好为 3。...,目标字段减去它对应的序号得到的的结果相同的数据则说明它们是连续的子序列。...3 11 8 3 14 9 5 15 10 5 id 为 3 ~ 5 是一个连续序列...,7 ~ 11 是一个连续序列,14 ~ 15 是一个连续序列。...由于我们只要获取长度为 3 的子序列,根据判断连续序列的规则,反过来说,如果一组数据连续序列,那么目标字段和它对应的序号分别加上固定的值,目标字段得到的结果和新序号的差值仍和做加法操作前保持一致。

89110

LeetCode-128-最长连续序列

# LeetCode-128-最长连续序列 给定一个未排序的整数数组,找出最长连续序列的长度。 要求算法的时间复杂度为 O(n)。...示例1: 输入: [100, 4, 200, 1, 3, 2] 输出: 4 解释: 最长连续序列是 [1, 2, 3, 4]。它的长度为 4。...zui-chang-lian-xu-xu-lie-by-leetcode-solution/ 我们考虑枚举数组中的每个数 x,考虑以其为起点,不断尝试匹配 x+1, x+2,⋯ 是否存在,假设最长匹配到了 x+y,那么以 x为起点的最长连续序列即为...但仔细分析这个过程,我们会发现其中执行了很多不必要的枚举,如果已知有一个 x, x+1, x+2, ⋯,x+y 的连续序列,而我们却重新从 x+1,x+2 或者是 x+y处开始尝试匹配,那么得到的结果肯定不会优于枚举

20120

Leetcode No.128 最长连续序列

一、题目描述 给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。 请你设计并实现时间复杂度为 O(n) 的算法解决此问题。...示例 1: 输入:nums = [100,4,200,1,3,2] 输出:4 解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。...^9 <= nums[i] <= 10^9 二、解题思路 我们考虑枚举数组中的每个数 x,考虑以其为起点,不断尝试匹配 x+1,x+2,⋯ 是否存在,假设最长匹配到了 x+y,那么以 x 为起点的最长连续序列即为...但仔细分析这个过程,我们会发现其中执行了很多不必要的枚举,如果已知有一个x,x+1,x+2,⋯,x+y 的连续序列,而我们却重新从 x+1,x+2 或者是 x+y 处开始尝试匹配,那么得到的结果肯定不会优于枚举...外层循环需要 O(n) 的时间复杂度,只有当一个数是连续序列的第一个数的情况下才会进入内层循环,然后在内层循环中匹配连续序列中的数,因此数组中的每个数只会进入内层循环一次。

16610

【Leetcode】128.最长连续序列

题目 给定一个未排序的整数数组,找出最长连续序列的长度。 要求算法的时间复杂度为 O(n)。...示例: 输入: [100, 4, 200, 1, 3, 2] 输出: 4 解释: 最长连续序列是 [1, 2, 3, 4]。它的长度为 4。...题解 这道题目最开始大家想的肯定是sort,然后计数计算最长序列。但是要求时间复杂度为:o(n),就不能用sort了。...基于这种思路我们就想要求最长的,就是要记录下有没有相邻的元素,比如遍历到100这个元素,我们需要查看[99, 101]这两个元素在不在序列中,这样去更新最大长度。...而记录元素有没有这个事我们太熟悉了,用set这种数据结构,而set这种数据结构是需要o(n)的空间来换取的,这就是我们刚才说的用空间来换时间。

37810
领券