`

LeetCode 163 - Missing Ranges

 
阅读更多

Given a sorted integer array where the range of elements are [0, 99] inclusive, return its missing ranges.
For example, given [0, 1, 3, 50, 75], return [“2”, “4->49”, “51->74”, “76->99”]

这也是Google Interview的电面题目。

[分析]
一遍线性扫描即可。

[注意事项]
1)针对一些特殊情况,询问面试官,比如说如果array是个空的,或者array包含区间内的所有元素,相应的返回值是什么
2)可以给出一些有意思的test case,另外就是不需要限制给出的范围是[0, 99],用start和end表示就行。在面试的时候可以先提一下,写出[0, 99]的代码,然后在稍作修改,变成start和end的版本。

public List<String> findMissingRanges(int[] vals, int start, int end) {
    List<String> ranges = new ArrayList<String>();
    int prev = start - 1;
    for (int i=0; i<=vals.length; ++i) {
        int curr = (i==vals.length) ? end + 1 : vals[i];
        if ( cur-prev>=2 ) {
            ranges.add(getRange(prev+1, curr-1));
        }
        rev = curr;
    }
    return ranges;
}

private String getRange(int from, int to) {
    return (from==to) ? String.valueOf(from) : from + "->" to;
}

 

另外一种写法:

public String missingRanges(int[] A) {
	int prev = -1, n = A.length;
	StringBuilder sb = new StringBuilder();
	for(int i=0; i<=n; i++) {
		int val = (i==n) ? 100 : A[i]; 
		if(val != prev+1) {
			int low = prev+1;
			int high = val-1;
			if(sb.length() != 0) sb.append(",");
			if(low == high) sb.append(low);
			else sb.append(low + "-" + high);
		}
		prev = val;
	}
	return sb.toString();
}

 

分享到:
评论

相关推荐

    LeetCode 101 - A LeetCode Grinding Guide (C++ Version).rar

    《LeetCode 101 - A LeetCode Grinding Guide (C++ Version)》是一本专为C++程序员设计的深入解析LeetCode算法问题的指南。这本书采用彩色版,以直观的方式讲解了各种数据结构和算法,旨在帮助读者磨练编程技能,...

    LeetCode 101 - A LeetCode Grinding Guide (C Version).pdf

    《LeetCode 101 - A LeetCode Grinding Guide (C++ Version)》是一本面向有一定C++编程基础,但缺乏刷题经验读者的教科书和工具书。作者高畅(Chang Gao)基于其在准备实习和秋招过程中对LeetCode题目的整理和刷题...

    js-leetcode题解之163-missing-ranges.js

    在解决LeetCode上的问题时,题号为163的“Missing Ranges”题是一道涉及数组操作和字符串格式化的问题。这类问题通常需要编写一个函数来找出数组中缺失的区间,然后以字符串形式返回所有缺失的范围。由于此题涉及多...

    python-leetcode题解之163-Missing-Ranges.py

    本篇内容将详细介绍如何用Python解决LeetCode上编号为163的“缺失区间”问题。在解决这个问题的过程中,我们将涉及到如何处理边界情况、如何有效地构建和返回结果字符串等编程技巧。 首先,我们需要明确题目的要求...

    LeetCode---C++实现

    《LeetCode---C++实现》是一本专注于C++编程语言解决LeetCode在线判题平台上的算法问题的书籍。LeetCode是程序员广泛使用的平台,它提供了大量的编程题目来提升编程技能和算法理解,尤其对于准备面试的程序员来说,...

    leetcode1-240题中文题解,md格式,java

    1. leetCode-126-Word-LadderII.md:这涉及到第126题,词梯问题,通常是一个字符串转换问题,目标是找到两个单词之间的最短转换序列,每次只改变一个字母。 2. leetcode-224-Basic-Calculator.md:这是第224题,基础...

    leetcode-leetcode-cli-plugins:leetcode-cli的第3方插件

    leetcode-cli-plugins leetcode-cli 的第 3 方插件。 什么是 如何使用 如何使用 插件 名称 描述 增强的命令 按公司或标签过滤问题 list 不要在同一台计算机上使 Chrome 的会话过期 login 不要在同一台计算机上使 ...

    离线和leetcode-leetcode-cn-cli:为leetcode-cn.com工作

    leetcode-cli 一个享受 leetcode 的高效 cli 工具! 非常感谢 leetcode.com,一个非常棒的网站! ⦙⦙⦙⦙⦙⦙⦙⦙ 一个很打问题的方法。 问题来缓解离线思考。 编码前的源代码。 居住和与 leetcode.com。 下载你...

    leetcode2sumc-leetcode-cli:leetcode-cli

    leetcode-cli 注意:这个存储库是为了临时使用而分叉的。 注意:从 webbrowser 复制 cookie 并使用leetcode user -c可以临时修复不能。 一个享受 leetcode 的高效 cli 工具! 非常感谢 leetcode.com,一个非常棒的...

    leetcode答案-leetcode--python:leetcode--python

    这个压缩包“leetcode--python”显然包含了与LeetCode相关的Python解题代码,可能是一个开源项目,用于存储用户或社区成员解决LeetCode问题的Python实现。 **LeetCode概述** LeetCode提供了一系列的算法和数据结构...

    leetcode26-algo:算法与数据结构

    leetcode26 algo 算法与数据结构,练习代码 语言:java 8 开发工具:vscode,安装插件Java Extension Pack vscode有智能提示,可调试,有重构支持,满足代码练习要求,相比IDEA更轻量级,普通笔记本即可流畅运行。 ...

    leetcode答案-Leetcode--Algo:Leetcode-某事

    leetcode 答案Leetcode---算法 我对 Leetcode 算法问题的回答

    leetcode接口-leetcodeHelper:leetcodeHelper

    leetcode 接口 该项目可帮助您使用首选的 IDE 或带有命令行界面 (CLI) 的编辑器来执行 leetcode。 入门 先决条件 Windows 10、MacOS、Linux Chrome版 &gt;=90.0.4430 安装 # Prepare your virtual environment conda ...

    leetcode答案-leetcode-machine-swift:Xcode中的leetcode解决方案验证

    leetcode-machine-swift :SOS_button: 请帮助在Sources/leetcode-machine-swift/leetcode.swift设置所有 leetcode 问题。 :SOS_button: 在 swift 编码时有 xcode 总是好的。 利用自动补全、类型检查...功能可以帮助...

    离线和leetcode-leetcode-cli-2.6.1:leetcode-cli-2.6.1

    leetcode-cli 一个享受 leetcode 的高效 cli 工具! 非常感谢 leetcode.com,一个非常棒的网站! ⦙⦙⦙⦙⦙⦙⦙⦙ 一个很打问题的方法。 问题来缓解离线思考。 编码前的源代码。 居住和与 leetcode.com。 下载你...

    leetcode2-leetcode-training:算法训练

    leetcode-训练 算法训练。 java $: javac hello.java java $: java hello c $: gcc hello.c 如果没有错误会生成a.out 可执行文件 c $: ./a.out leetcode cli leetcode version leetcode help leetcode help user ...

    zwangZJU#LeetCode-in-python-wznote#LeetCode-python-739-每日温度1

    解题思路思路和LeetCode-python 503.下一个更大元素 II一致,只是这里求的是下标的距离,而不是数值倒序搜索,用到栈,栈里存储索引情况1:若栈为

    leetcode2-21-DAYS-PROGRAMMING-CHALLENGE-ACES:编码CP,探索新事物

    leetcode 2 21 天-编程-挑战-ACES CP、探索新事物、Web 开发 第一天: 解决了 leetcode 问题 - 10 月 4 日 解决 codechef 十月挑战问题 写了一些关于 GFG 的文章 第 2 天: 解决了 leetcode 问题 - 10 月 5 日和 6 ...

    leetcode中国-leetcode-rust-cn:用Rust刷LeetCode,带中文注释

    leetcode-rust-cn LeetCode solutions in Rust, with Chinese comment. 用 Rust 刷 LeetCode,带中文注释 VSCode 插件 ,插件用法见其 插件 插件 切换到 LeetCode 英文版,然后通过第三方帐号(如 GitHub)登录 用法:...

    LeetCode--Linked List.cpp

    文件中包含了LeetCode中Tag为LinkedList的题目参考代码。

Global site tag (gtag.js) - Google Analytics