首页 > 其他 > 详细

[LeetCode]135 Candy

时间:2015-01-08 18:15:25      阅读:216      评论:0      收藏:0      [点我收藏+]

https://oj.leetcode.com/problems/candy/

http://blog.csdn.net/linhuanmars/article/details/21424783

public class Solution {
    public int candy(int[] ratings) {
        
        // 从左边向右边 遍历
        // 如果 这个 比 前一个大, ++
        // 否则 持平
        // 这样保证左右 小孩 和他 右边的人比较 是合法的
        //
        // 同理 向 左边 遍历
        
        int len = ratings.length;
        
        int[] left = new int[len];
        left[0] = 1;
        for (int i = 1 ; i < len ; i ++)
        {
            left[i] = 1;
            if (ratings[i] > ratings[i - 1])
                left[i] = left[i - 1] + 1;
        }

        int[] right = new int[len];
        right[len - 1] = 1;
        for (int i = len - 2 ; i >= 0 ; i --)
        {
            right[i] = 1;
            if (ratings[i] > ratings[i + 1])
                right[i] = right[i + 1] + 1;
        }        
        
        int sum = 0;
        for (int i = 0 ; i < len ; i ++)
        {
            sum += Math.max(left[i], right[i]);
        }
        return sum;
    }
}


[LeetCode]135 Candy

原文:http://7371901.blog.51cto.com/7361901/1600761

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!