题解 | #分糖果问题#

分糖果问题

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
};

全部评论

相关推荐

01-14 12:08
门头沟学院 Java
神哥了不得:(非引流)1.既然发出来了简历,就稍微提一点点小建议,确实简历很不错了,练手项目可以换一些质量高的,工作内容,可以加上一些量化指标,比如第一条系统响应速度由多少变成多少,减少了百分之多少,第4条就很不错。2.广投,年前实习招募比较少了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务