码迷,mamicode.com
首页 > 其他好文 > 详细

Jan 12 - Summary Ranges;Array;String

时间:2016-01-13 07:03:49      阅读:202      评论:0      收藏:0      [点我收藏+]

标签:

Functions of StringBuilder:

技术分享

技术分享

代码:

public class Solution {
    public List<String> summaryRanges(int[] nums) {
        List<String> list = new ArrayList<>();
        if(nums.length == 0) return list;
        int head = 0;
        int k = -1;
        StringBuilder sb = new StringBuilder();
        for(int i = 0; i < nums.length; i++){
            if(i == 0){
                sb.append(nums[i]);
                if(i == nums.length-1){
                    list.add(sb.toString());
                    break;
                }
                sb.append(‘,‘);
                head = nums[i];
            }
            else if(nums[i] > head + 1){
                String[] tokens = sb.toString().split(",");
                if(tokens.length == 1) list.add(tokens[0]);
                if(tokens.length > 1){
                    String s = tokens[0]+"->"+tokens[tokens.length-1];
                    list.add(s);
                }
                sb = new StringBuilder();
                sb.append(nums[i]);
                if(i == nums.length-1){
                    list.add(sb.toString());
                    break;
                }
                sb.append(‘,‘);
                head = nums[i];
            }
            else{
                sb.append(nums[i]);
                if(i == nums.length-1){
                    String[] tokens = sb.toString().split(",");
                    String s = tokens[0]+"->"+tokens[tokens.length-1];
                    list.add(s);
                    break;
                }
                sb.append(‘,‘);
                head = nums[i];
            }
        }
        return list;
    }
}

  网上的代码:

public class Solution {
    public List<String> summaryRanges(int[] nums) {
        List<String> list = new ArrayList<>();
        if(nums.length == 0) return list;
        int high = 0, low = 0;
        int length = nums.length;
        //int k = -1;
        while(high < length){
            if(high < length-1 && nums[high]+1 == nums[high+1]){
                high++;
            }
            else{
                if(low == high) list.add(String.valueOf(nums[high]));
                else list.add(nums[low]+"->"+nums[high]);
                high++;
                low = high;
            }
        }
        return list;
        
    }
}

 

Jan 12 - Summary Ranges;Array;String

标签:

原文地址:http://www.cnblogs.com/5683yue/p/5126121.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!