[Java][Leetcode hard] 135. 分发糖果

没做出来

官解1: 两次循环分别求i左右侧糖果数量限制,取二者最大值。

java 复制代码
class Solution {
    public int candy(int[] ratings) {
        int n = ratings.length;
        
        int[] left = new int[n];
        // i左侧的糖果数需要满足的要求:保证满足上升趋势需求
        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;
            }
        }

      // i右侧的糖果数需要满足的要求:保证满足下降趋势需求
      // 例如 3、2、1  那么为了保证1最小糖果为1-->对应的元素为1,那么2-->最小是2,3--->3.
        int right = 0, res = 0;
        for(int i=n-1;i>=0;i--){
            if(i < n-1 && ratings[i] > ratings[i+1] ){
                right++;
            }else{
                right = 1;
            }
            
            res += Math.max(right, left[i]);  
            // 左右糖果的限制,取二者的最大值:保证同时满足二者的要求
        }

        return res;
    }
}

常量空间解法

解释一下这里为什么要 res++:考虑一下这个样例: 1 3 2 1:

如果不加1的话,按照这个代码: 糖果是:1 2 1 2 但是很明显321的话 3对应的人应该最少分3个糖果,这就会出现错误。

if(down >= up){

res++;

}

java 复制代码
class Solution {
    public int candy(int[] ratings) {
        int n = ratings.length;
        
        int res = 1;

        // 默认第一个元素为上升序列
        int cur = 1;  // 记录上升过程中的,应该最少的糖果数
        int up = 1;  // 记录上升趋势
        int down = 0; // 记录下降趋势

        for(int i=1;i<n;i++){
            if(ratings[i]> ratings[i-1]){
                // 上升序列
                down = 0;

                cur++;
                up = cur;

                res += cur;
            }else if(ratings[i] == ratings[i-1]){
                down = 0;
                cur = 1;
                up = 1;

                res += 1;
            }else{
                down ++; 
                cur = 1;

                res += down;
                if(down >= up){
                   res++;
                }
            }
        }

        return res;
    }
}
相关推荐
2601_954526752 分钟前
逆向解析Temu底层动销算法:基于API高并发轮询与全域存量透视的自动化架构重构
算法·架构·自动化
摇滚侠10 分钟前
针对主键索引的 for update 操作有什么用
java
RainCity29 分钟前
Java Swing 自定义组件库分享(六)
java·笔记·后端
Σίσυφος190029 分钟前
数据标准化(拟合的时候使用非常重要)
人工智能·算法
xuanjiong33 分钟前
DDD架构Repository仓储数据流转全链路详解:Domain与其他层的数据流转
java·系统架构
knight_9___39 分钟前
大模型project面试7
人工智能·python·算法·面试·大模型·agent
吴声子夜歌1 小时前
Java——类加载机制
java·开发语言·python
Xiacqi11 小时前
Java 中 String、StringBuffer、StringBuilder 的区别
java
Xiacqi11 小时前
Java 常用集合框架手册
java
笨蛋不要掉眼泪1 小时前
Java并发编程:线程的创建和运行
java·开发语言·jvm