Given a sorted integer array without duplicates, return the summary of its ranges.
For example, given [0,1,2,4,5,7], return [“0->2”,”4->5”,”7”].
解答:
思路还是很清晰的,只是要code出来还是不容易的。
注意不要新定义一个string去存东西。
class Solution {
public:
vector<string> summaryRanges(vector<int>& nums) {
int i=0;
int n=nums.size();
vector<string> ret;
while(i<n)
{
int j=1;
while(i+j<n&&nums[i+j]-nums[i]==j) j++;
if(j==1)
ret.push_back(to_string(nums[i]));
else
ret.push_back(to_string(nums[i])+"->"+to_string(nums[i+j-1]));
i+=j;
}
return ret;
}
};