网站运营师,制作asp.net网站,seo项目完整流程,厦门哪里有教网站建设原题链接#xff1a;https://leetcode.cn/problems/summary-ranges/description/
228. 汇总区间
给定一个 无重复元素 的 有序 整数数组 nums 。
返回 恰好覆盖数组中所有数字 的 最小有序 区间范围列表 。也就是说#xff0c;nums 的每个元素都恰好被某个区间范围所覆盖https://leetcode.cn/problems/summary-ranges/description/
228. 汇总区间
给定一个 无重复元素 的 有序 整数数组 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” 提示 0 nums.length 20 -231 nums[i] 231 - 1 nums 中的所有值都 互不相同 nums 按升序排列 golang
func summaryRanges(nums []int) []string {if len(nums) 0 {return nil}var l, r intvar ret []stringfor i : 1; i len(nums); i {if nums[i] ! nums[i-1] 1 {if l r {ret append(ret, fmt.Sprint(nums[l]))} else {ret append(ret, fmt.Sprint(nums[l]) - fmt.Sprint(nums[r]))}l ir i}else {r i}}if l r {ret append(ret, fmt.Sprint(nums[l]))} else {ret append(ret, fmt.Sprint(nums[l]) - fmt.Sprint(nums[r]))}return ret
}c
class Solution {
public:vectorstring summaryRanges(vectorint nums) {vectorstring ret;if (nums.size() 0) {return ret;}int l 0, r 0;for (int i 1; i nums.size(); i) {if (nums[i] ! nums[i-1] 1) {if (l r) {ret.push_back(to_string(nums[l]));} else {ret.push_back(to_string(nums[l]) - to_string(nums[r]));}l i;r i;} else {r i;}}if (l r) {ret.push_back(to_string(nums[l]));} else {ret.push_back(to_string(nums[l]) - to_string(nums[r]));}return ret;}
};