栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

leetcode-分糖果问题-84

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

leetcode-分糖果问题-84

题目要求

代码实现

#include 
class Solution {
public:
    int candy(vector& arr) {
        vector num(arr.size(), 1);
        int count = 0;
        //从左到右遍历,保证右边如果大于左边,右边糖果也多于左边
        for(int i = 1; i < arr.size(); i++)
        {
            if(arr[i] > arr[i - 1])
            {
                num[i] = num[i - 1] + 1;
            }
        }
        //从右往左遍历,保证左边如果大于右边,左边糖果也多于右边
        for(int i = arr.size() - 1; i > 0; i--)
        {
            if(arr[i - 1] > arr[i])
            {
                num[i - 1] = max(num[i] + 1, num[i - 1]);
            }
        }
        //计数
        for(auto i : num)
        {
            count += i;
        }
        return count;
    }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/767245.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号