这是一道hard题,不好想,但最后还是想出来了,私以为还是根据一些思想方法自己想出来做法印象比较深刻,其次看人家的做法思想自己写代码,其次看代码理解默写,其次直接抄代码;

首先,给每个孩子都发一个糖果vector<int> res(len,1),  然后调整,

正向调整,如果当前孩子比之前孩子的分数高,那么令当前孩子的糖果数比之前孩子糖果数大1 res[i]=res[i-1]+1;

反向调整,如果当前孩子比之前孩子的分数高,那么比较当前孩子的糖果数和之前孩子的糖果数+1,取更大的为当前孩子糖果数res[i]=max(res[i],res[i+1]+1);

最后,将每个孩子的糖果数加起来;sum(res.begin(),res.end());

class Solution {
public: int candy(vector<int>& ratings) {
int len=ratings.size();
vector<int> res(len,);
for(int i=;i<len;i++){
if(ratings[i]>ratings[i-]){
res[i]=res[i-]+;
}
}
for(int i=len-;i>=;i--){
if(ratings[i]>ratings[i+]){
res[i]=max(res[i],res[i+]+);
//cout<<"1"<<endl;
}
}
int sum=;
for(int n:res){
sum+=n;
} return sum;
} };

最新文章

  1. mybatis 动态sql表达式相关应用
  2. Tech Websites
  3. 优化UITableViewCell高度计算的那些事
  4. vertical-align的理解
  5. LeetCode Course Schedule II
  6. Android ActivityThread(主线程或UI线程)简介
  7. 生成1~n的全排列
  8. C# 跨线程操作控件(简洁)
  9. 微软职位内部推荐-Android Developer
  10. Excel数据导入导出
  11. mysql binlog 混合模式 出现的基于sql的数据不一致,主要是now()这类函数导致
  12. Mysql自动填充测试数据
  13. db2备份还原
  14. HashMap面试题:90%的人回答不上来
  15. datanode启动不起来的各种原因
  16. 追女神助手v0.1
  17. 自动布局Autoresizing与Autolayout
  18. 【AtCoder078D】Fennec VS. Snuke
  19. Fork/Join框架
  20. 搭建Modelsim SE仿真环境-使用do文件仿真

热门文章

  1. 仿造email后缀搜索功能(2)
  2. HttpClient 释放连接
  3. 从FBV到CBV四(访问频率限制)
  4. 阿里域名 ssl tomcat
  5. Linux如何将pycharm添加到桌面
  6. mysql5.7.26 基于GTID的主从复制环境搭建
  7. centos7 nginx 代理
  8. DevExpress ASP.NET Core v19.1版本亮点:Rich Text Editor
  9. Phantomjs 请求与响应
  10. 微信小程序let和var以及const有什么区别