leetcode算法228.汇总区间

简介: 如何用leetcode算法228.汇总区间?本文带大家解决这个问题。

一、leetcode算法



1、汇总区间


1.1、题目


给定一个无重复元素的有序整数数组 nums 。


返回恰好覆盖数组中所有数字的最小有序区间范围列表 。也就是说,nums 的每个元素都恰好被某个区间范围所覆盖,并且不存在属于某个范围但不属于 nums 的数字 x 。


列表中的每个区间范围 [a,b] 应该按如下格式输出:


“a->b” ,如果 a != b

“a” ,如果 a == b


示例 1:


输入:nums = [0,1,2,4,5,7]

输出:[“0->2”,“4->5”,“7”]

解释:区间范围是:

[0,2] --> “0->2”

[4,5] --> “4->5”

[7,7] --> “7”


示例 2:


输入:nums = [0,2,3,4,6,8,9]

输出:[“0”,“2->4”,“6”,“8->9”]

解释:区间范围是:

[0,0] --> “0”

[2,4] --> “2->4”

[6,6] --> “6”

[8,9] --> “8->9”


1.2、思路


思路一:此题我们可以对数据进行一次遍历,从左向右开始遍历,判断相邻两个数是否差值为1,如果为1则加入字符串“->”,如果不为1,则进行单独插入。


1.3、答案


14.png


class Solution {
    public List<String> summaryRanges(int[] nums) {
        List<String> ret = new ArrayList<String>();
        int i = 0;
        int n = nums.length;
        while(i < n){
            int low = i;
            i++;
            //如果相连的数据都大于1则循环
            while(i < n && nums[i] == nums[i - 1] + 1){
                i++;
            }
            int high = i - 1;
            StringBuffer temp = new StringBuffer(Integer.toString(nums[low]));
            if(low < high){
                temp.append("->");
                temp.append(Integer.toString(nums[high]));
            }
            ret.add(temp.toString());
        }
        return ret;
    }
}


复杂度分析


时间复杂度:O(n),其中 n 为数组的长度。


空间复杂度:O(1)。除了用于输出的空间外,额外使用的空间为常数。


相关文章
|
1月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
39 0
|
17天前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
1月前
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
27 2
|
1月前
|
算法
Leetcode第57题(插入区间)
LeetCode第57题“插入区间”的解题方法,包括题目描述、示例、算法思路和代码实现,旨在解决将新区间插入有序且不重叠的区间列表中,并合并重叠区间的问题。
18 0
Leetcode第57题(插入区间)
|
3月前
|
算法
测试工程师的技能升级:LeetCode算法挑战与职业成长
这篇文章通过作者亲身体验LeetCode算法题的过程,探讨了测试工程师学习算法的重要性,并强调了算法技能对于测试职业成长的必要性。
70 1
测试工程师的技能升级:LeetCode算法挑战与职业成长
|
3月前
|
算法
LeetCode第57题插入区间
LeetCode第57题"插入区间"的解题方法,利用原区间集有序的特性,通过三步插入操作,有效实现了新区间的插入和重叠区间的合并。
LeetCode第57题插入区间
|
3月前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
52 6
|
3月前
|
存储 算法 Java
LeetCode经典算法题:打家劫舍java详解
LeetCode经典算法题:打家劫舍java详解
70 2
|
3月前
|
人工智能 算法 Java
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
50 1
|
3月前
|
存储 算法 Java
LeetCode经典算法题:预测赢家+香槟塔java解法
LeetCode经典算法题:预测赢家+香槟塔java解法
61 1
下一篇
无影云桌面