day26(12.6)——leetcode面试经典150

228. 汇总区间

228. 汇总区间

题目:


题解:

第一版是我最开始想的,后面都是优化完成的,但是第二版和第三版区别感觉没有很大

java 复制代码
class Solution {
    public List<String> summaryRanges(int[] nums) {
        List<String> list = new ArrayList<>();
        Set<Long> ss = Arrays.stream(nums)
            .mapToLong(i -> (long) i)   
            // IntStream → LongStream
            .boxed()                    
            // LongStream → Stream<Long>
            .collect(Collectors.toSet());
        Set<Long> set = new TreeSet<>(ss);
        for(Long s:set) {
            if(!set.contains(s-1)) {
                long l = s;
                long r = s;
                while(set.contains(r)) {
                    r++;
                }
                r--;
                if(l!=r) {
                    list.add(String.valueOf(l)+"->"+r);
                }
                else {
                    list.add(String.valueOf(l));
                }
            }
        }
        return list;
    }
}
java 复制代码
class Solution {
    public List<String> summaryRanges(int[] nums) {
        List<String> list = new ArrayList<>();
        Arrays.sort(nums);
        for(int i=0;i<nums.length;) {
            int l = nums[i];
            int r = nums[i];
            while(i<nums.length&&r==nums[i]) {
                i++;
                r++;
            }
            r--;
            if(l==r) {
                list.add(String.valueOf(l));
            }
            else {
                list.add(String.valueOf(l)+"->"+String.valueOf(r));
            }
        }
        return list;
    }
}
java 复制代码
class Solution {
    public List<String> summaryRanges(int[] nums) {
        List<String> list = new ArrayList<>();
        if(nums == null || nums.length==0) {
            return list;
        }
        Arrays.sort(nums);
        int l = nums[0];
        int r = nums[0];
        for(int i=0;i<nums.length;i++) {
            if(r==nums[i]) {
                r++;
            }
            else {
                r--;
                if(l==r) {
                    list.add(String.valueOf(l));
                }
                else {
                    list.add(String.valueOf(l)+"->"+String.valueOf(r));
                }
                l=nums[i];
                r=nums[i];
                i--;
            }
        }
        r--;
        if(l==r) {
            list.add(String.valueOf(l));
        }
        else {
            list.add(String.valueOf(l)+"->"+String.valueOf(r));
        }
        return list;
    }
}
相关推荐
甄心爱学习25 分钟前
KMP算法(小白理解)
开发语言·python·算法
wen__xvn1 小时前
牛客周赛 Round 127
算法
大锦终1 小时前
dfs解决FloodFill 算法
c++·算法·深度优先
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——LeetCode 200 题:岛屿数量
算法·leetcode·职场和发展
苦藤新鸡1 小时前
14.合并区间(1,3)(2,5)=(1,5)
c++·算法·leetcode·动态规划
程序员-King.1 小时前
day145—递归—二叉树的右视图(LeetCode-199)
算法·leetcode·二叉树·递归
漫随流水1 小时前
leetcode算法(112.路径总和)
数据结构·算法·leetcode·二叉树
过期的秋刀鱼!1 小时前
机器学习-带正则化的成本函数-
人工智能·python·深度学习·算法·机器学习·逻辑回归
ScilogyHunter1 小时前
前馈/反馈控制是什么
算法·控制
oscar9991 小时前
软件测试面试全攻略之高级篇
面试·职场和发展·测试高级