Leetcode049--最长连续子数组

Posted 劲火星空

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode049--最长连续子数组相关的知识,希望对你有一定的参考价值。

一、原题



Given an unsorted array of integers, find the length of the longest consecutive elements sequence.

For example,
Given[100, 4, 200, 1, 3, 2],
The longest consecutive elements sequence is[1, 2, 3, 4]. Return its length:4.

Your algorithm should run in O(n) complexity.



一、中文



给出一个数组,求出里面能够组成的最长连续子数组的长度并返回



三、举例



比如数组[100, 4, 200, 1, 3, 2]中的最长子数组的长度就是[1, 2, 3, 4]



四、思路



首先对数组进行排序,然后将排序后的数组进行查找,从最左边开始,如果相邻就加一,如果不相邻就将其置零


五、程序


import java.util.*;

public class Solution 
    //发现连续的子字符串
    public int longestConsecutive(int[] num) 
        //排序
        Arrays.sort(num);
        
        int max = 1;
        int count = 1;
        for(int i = 1; i < num.length; i++)
            if((num[i] - num[i-1]) == 1)
                count++;
                if(count > max)
                    max = count;
                
            else if(num[i] - num[i-1] == 0)
                continue;
            else
                count = 1;
            
            
        
        return max;
    





以上是关于Leetcode049--最长连续子数组的主要内容,如果未能解决你的问题,请参考以下文章

[leetcode] No.1438 绝对差不超过限制的最长连续子数组

[leetcode] No.1438 绝对差不超过限制的最长连续子数组

leetcode-525连续数组

《LeetCode之每日一题》:49.连续数组

每日一题系列-leetcode-525-连续数组

leetcode No525 连续数组 java