Leetcode 第228题 Summary Ranges

题目:Summary Ranges

  • 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”].

    Credits:
    Special thanks to @jianchao.li.fighter for adding this problem and creating all test cases.

    Subscribe to see which companies asked this question


题目分析:

  • 通过判断是否连续,来判断字符串应该如何表达

代码:

  • Javascript
Javascript:[byself]
/**
 * @param {number[]} nums
 * @return {string[]}
 */
var summaryRanges = function(nums) {
    var arr=[];//arr用于存放最后返回的数组

    var front=0;//范围开始的第一个数字
    var temp=0;//范围开始的最后一个数字
    var i=0;
    var j=0;//是范围开始的数字的index
    var cont=0;//如果cont是0 那么代表含义是这个数字前后断开,单独字符串 ; 如果cont不是零,那么代表字符串类似1->2

    while(i<nums.length)
    {
        front=nums[j];
        temp=nums[i];
        if(i+1<nums.length && nums[i+1]==temp+1)//如果i不是倒数第二个,并且满足数组中前后两个数字之间是连续的
        {
            i++;
            cont++;
        }
        else//如果i是倒数第二个或数组中前后两个数值之间不是连续的
        {
            var str='';
            if(cont==0)//通过cont来区分是单个数字组成字符串还是连续数字范围构成的字符串
            {
                str+=front;
                arr.push(str);
            }
            else
            {
                str+=front+"->"+temp;
                arr.push(str);
            }
            j=i+1;
            i++;
            cont=0;
        }
    }
    return arr;
};
  • C++:[代码参考别人的,不是很懂C++语法,但是算法思路自己想的]
class Solution {
public:
    vector<string> summaryRanges(vector<int>& nums) {
        vector<string> result;  
        if (nums.size()<1)  
            return result;  
        int begin, end;  
        begin = end = nums[0];  
        for (int i=1; i<nums.size(); i++)  
        {  
            if (nums[i] ==end || nums[i]==end+1)  
            {  
                end = nums[i];  
            }   
            else  
            {  
                result.push_back(format(begin, end));  
                begin = end = nums[i];  
            }  
        }  
        result.push_back(format(begin, end));  
        return result; 
    }
    string format(int begin, int end)  
    {  
        char buffer[32];  
        if (end == begin)  
        {  
            sprintf(buffer, "%d", begin);  
        }else{  
            sprintf(buffer, "%d->%d", begin, end);  
        }  
        return string(buffer);  
    }  
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值