Java | Leetcode Java题解之第135题分发糖果

题目:

题解:

java 复制代码
class Solution {
    public int candy(int[] ratings) {
        int n = ratings.length;
        int ret = 1;
        int inc = 1, dec = 0, pre = 1;
        for (int i = 1; i < n; i++) {
            if (ratings[i] >= ratings[i - 1]) {
                dec = 0;
                pre = ratings[i] == ratings[i - 1] ? 1 : pre + 1;
                ret += pre;
                inc = pre;
            } else {
                dec++;
                if (dec == inc) {
                    dec++;
                }
                ret += dec;
                pre = 1;
            }
        }
        return ret;
    }
}
相关推荐
Dream it possible!14 分钟前
LeetCode 热题 100_寻找重复数(100_287_中等_C++)(技巧)(暴力解法;哈希集合;二分查找)
c++·leetcode·哈希算法
forestsea1 小时前
Maven 插件扩展点与自定义生命周期
java·maven
keke102 小时前
Java【14_2】接口(Comparable和Comparator)、内部类
java·开发语言
CN.LG2 小时前
Java 乘号来重复字符串的功能
java·开发语言
萌新下岸多多关照2 小时前
Java中synchronized 关键字
java·开发语言
中国lanwp2 小时前
使用Maven部署WebLogic应用
java·maven
开开心心就好2 小时前
Word图片格式调整与转换工具
java·javascript·spring·eclipse·pdf·word·excel
CGG923 小时前
【单例模式】
android·java·单例模式
苦学编程的谢3 小时前
多线程代码案例-1 单例模式
java·开发语言·单例模式
yaoxin5211233 小时前
80. Java 枚举类 - 使用枚举实现单例模式
java·开发语言·单例模式