LeetCode 刷题【135. 分发糖果】

135. 分发糖果

自己做(歇菜)

看题解

官方题解

java 复制代码
class Solution {
    public int candy(int[] ratings) {
        int n = ratings.length;
        int[] left = new int[n];
        for (int i = 0; i < n; i++) {
            if (i > 0 && ratings[i] > ratings[i - 1]) {
                left[i] = left[i - 1] + 1;
            } else {
                left[i] = 1;
            }
        }
        int right = 0, ret = 0;
        for (int i = n - 1; i >= 0; i--) {
            if (i < n - 1 && ratings[i] > ratings[i + 1]) {
                right++;
            } else {
                right = 1;
            }
            ret += Math.max(left[i], right);
        }
        return ret;
    }
}
相关推荐
sqyno1sky10 分钟前
C++中的契约编程
开发语言·c++·算法
优化控制仿真模型22 分钟前
2026年最新驾考科目一考试题库2309道全。电子版pdf
经验分享·算法·pdf
qq_3349031525 分钟前
嵌入式C++驱动开发
开发语言·c++·算法
阿贵---36 分钟前
C++代码规范化工具
开发语言·c++·算法
暮冬-  Gentle°44 分钟前
自定义内存检测工具
开发语言·c++·算法
ccLianLian1 小时前
数论·欧拉函数
数据结构·算法
2501_945424801 小时前
C++编译期矩阵运算
开发语言·c++·算法
2301_815482931 小时前
C++中的类型标签分发
开发语言·c++·算法
xushichao19891 小时前
代码生成优化技术
开发语言·c++·算法
li星野1 小时前
RTOS面试完整模拟题(嵌入式系统方向)
arm开发·面试·职场和发展