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;
    }
}
相关推荐
okseekw4 分钟前
Java String类详解:不可变性、创建方式与比较方法
java
q***64975 分钟前
Spring Boot 各种事务操作实战(自动回滚、手动回滚、部分回滚)
java·数据库·spring boot
降临-max16 分钟前
JavaSE---网络编程
java·开发语言·网络·笔记·学习
橘颂TA31 分钟前
【剑斩OFFER】算法的暴力美学——只出现一次的数字 ||
算法·leetcode·动态规划
带刺的坐椅1 小时前
Solon AI 开发学习5 - chat - 支持哪些模型?及方言定制
java·ai·openai·solon
悟空码字1 小时前
单点登录:一次登录,全网通行
java·后端
傻啦嘿哟1 小时前
物流爬虫实战:某丰快递信息实时追踪技术全解析
java·开发语言·数据库
倚肆1 小时前
Spring Boot Security 全面详解与实战指南
java·spring boot·后端
茄子凉心1 小时前
android 开机启动App
android·java·开发语言
8***f3951 小时前
工作中常用springboot启动后执行的方法
java·spring boot·后端