题解 | #分糖果问题#

分糖果问题

https://www.nowcoder.com/practice/76039109dd0b47e994c08d8319faa352

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * pick candy
 * @param arr int整型一维数组 the array
 * @return int整型
 */
function candy( arr ) {
    // write code here
    let len = arr.length;
    if(len<=1)return 1
    let left = 0;
    let right = len-1;
    let dp = Array.from({length:len},()=>1);
	//左右遍历一次,即可
    for(let i = left+1;i<len;i++){
        if(arr[i]>arr[i-1]){
            dp[i] = dp[i-1]+1
        }
    }
    for(let i=right-1;i>=0;i--){
        if(arr[i]>arr[i+1]){
            dp[i] = Math.max(dp[i],dp[i+1]+1)
        }
    }
    return dp.reduce((a,b)=>a+b)
}
module.exports = {
    candy : candy
};

全部评论

相关推荐

头像
02-15 16:23
中南大学 Java
野猪不是猪🐗:签了美团真是不一样! 亲戚们都知道我签了美团,过年都围着我问送一单多少钱,还让弟弟妹妹们引以为戒,笑我爸我妈养了个🐢孩子,说从小就知道我这个人以后肯定没出息,我被骂的都快上天了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务