首页 > 代码库 > Missing Ranges 解答
Missing Ranges 解答
Question
Given a sorted integer array where the range of elements are in the inclusive range [lower, upper], return its missing ranges.
For example, given [0, 1, 3, 50, 75]
, lower = 0 and upper = 99, return ["2", "4->49", "51->74", "76->99"].
Answer
遍历数组,如果arr[i] > arr[i-1] + 1则说明arr[i]与arr[i-1]中有missing range。注意考虑开头和结尾。
1 public class Solution { 2 public List<String> findMissingRanges(int[] nums, int lower, int upper) { 3 List<String> result = new ArrayList<>(); 4 if (nums == null || nums.length == 0) { 5 addRange(result, lower, upper); 6 return result; 7 } 8 int len = nums.length; 9 // process head 10 if (nums[0] > lower) { 11 addRange(result, lower, nums[0] - 1); 12 } 13 for (int i = 1; i < len; i++) { 14 if (nums[i] > nums[i - 1] + 1) { 15 addRange(result, nums[i - 1] + 1, nums[i] - 1); 16 } 17 } 18 // process tail 19 if (nums[len - 1] < upper) { 20 addRange(result, nums[len - 1] + 1, upper); 21 } 22 return result; 23 } 24 25 private void addRange(List<String> result, int low, int high) { 26 StringBuilder sb = new StringBuilder(); 27 sb.append(low); 28 if (high > low) { 29 sb.append("->"); 30 sb.append(high); 31 } 32 result.add(sb.toString()); 33 } 34 }
Missing Ranges 解答
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。