热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

leetcode135.分发糖果(相邻的孩子中,评分高的必须糖果更多)思维

classSolution{public:intcandy(vector&a){intna.size(),sum0;if(n

在这里插入图片描述

class Solution {
public:int candy(vector<int>& a) {int n&#61;a.size(),sum&#61;0;if(n<&#61;1) return n;sum&#61;1;//pre的用处就是假如[3,7]是下坡 pre的值就是之前3分配的高度,然后[4,7]小朋友分别对应0,-1,-2,-3 这些小朋友都要增加4个糖果, //然后假如pre不大于等于5(第四个小朋友分配了0&#43;4&#61;4 所以第三个要>&#61;5)的话,也要多给第3个小朋友分配糖果for(int i&#61;0,pre&#61;1;i<n-1;){if(a[i&#43;1]>a[i]){int cnt&#61;1;//第i个小朋友的糖果已经在之前的下坡或者等坡分配好了.while(i<n-1&&a[i&#43;1]>a[i]) &#43;&#43;cnt,sum&#43;&#61;cnt,&#43;&#43;i;//i&#43;1(i还没&#43;&#43;之前的i&#43;1)需要分配的糖果是cntpre&#61;cnt;//更新precontinue;}if(a[i&#43;1]<a[i]){//i->i&#43;1 就是下坡了,i现在分配的糖果是pre个int di&#61;i,cnt&#61;1;while(i<n-1&&a[i&#43;1]<a[i]) --cnt,sum&#43;&#61;cnt,&#43;&#43;i;//i&#43;1(i还没&#43;&#43;之前的i&#43;1)需要分配的糖果是cntif(cnt<&#61;0){sum&#43;&#61;(i-di)*(1-cnt);//第[di&#43;1,i]个每个人需要增加(1-cnt)个糖果if(pre<1&#43;1-cnt) sum&#43;&#61;1&#43;1-cnt-pre;//多给第di个小朋友分配}//下坡之后不会是下坡(否则while不会跳出来),所以不需要更新precontinue;}if(a[i&#43;1]&#61;&#61;a[i]){//比如[1,5]等坡 那么1是取原来的值,[2,5]都取1 然后5或许会被下坡更新(假如5紧跟一个下坡且1满足不了)while(i<n-1&&a[i&#43;1]&#61;&#61;a[i]) sum&#43;&#61;1,&#43;&#43;i;pre&#61;1;//更新precontinue;}}return sum;}
};

class Solution {
public:int candy(vector<int>& a) {int n&#61;a.size(),sum&#61;0;if(n<&#61;1) return n;sum&#61;1;cout<<"第0个小朋友有1个糖果"<<endl;for(int i&#61;0,pre&#61;1;i<n-1;){if(a[i&#43;1]>a[i]){cout<<i<<" --> "<<i&#43;1<<"开始上坡了"<<endl;int cnt&#61;1;//第i个小朋友的糖果已经在之前的下坡分配好了.while(i<n-1&&a[i&#43;1]>a[i]){&#43;&#43;cnt,sum&#43;&#61;cnt;//i&#43;1需要分配的糖果是cntcout<<"第"<<i&#43;1<<"个小朋友有"<<cnt<<"个糖果"<<endl;&#43;&#43;i;}pre&#61;cnt;continue;}if(a[i&#43;1]<a[i]){//i->i&#43;1 就是下坡了,i现在分配的糖果是pre个cout<<i<<" --> "<<i&#43;1<<"开始下坡了"<<endl;int di&#61;i,cnt&#61;1;while(i<n-1&&a[i&#43;1]<a[i]){--cnt,sum&#43;&#61;cnt;//第i&#43;1个小朋友分配cnt个cout<<"第"<<i&#43;1<<"个小朋友有"<<cnt<<"个糖果"<<endl;//可见第di&#43;1以及往后分配是从0开始减的&#43;&#43;i;}if(cnt<&#61;0){sum&#43;&#61;(i-di)*(1-cnt);//第[di&#43;1,i]个每个人需要增加(1-cnt)个糖果cout<<"第["<<di&#43;1<<","<<i<<"]个小朋友每个人需要增加"<<1-cnt<<"个糖果"<<endl;if(pre<1&#43;1-cnt) {//上面di&#43;1及以后从0开始减 这里的di取得就是1 本来应该是(1&#43;1-cnt)的结果前面取了pre个 所以要增加sum&#43;&#61;1&#43;1-cnt-pre;cout<<"第"<<di<<"个小朋友需要增加"<<1&#43;1-cnt-pre<<"个糖果"<<endl;}}continue;}if(a[i&#43;1]&#61;&#61;a[i]){cout<<i<<" --> "<<i&#43;1<<"开始等坡了"<<endl;while(i<n-1&&a[i&#43;1]&#61;&#61;a[i]){sum&#43;&#61;1;cout<<"第"<<i&#43;1<<"个小朋友有"<<1<<"个糖果"<<endl;&#43;&#43;i;}pre&#61;1;continue;}}return sum;}
};

推荐阅读
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • IB 物理真题解析:比潜热、理想气体的应用
    本文是对2017年IB物理试卷paper 2中一道涉及比潜热、理想气体和功率的大题进行解析。题目涉及液氧蒸发成氧气的过程,讲解了液氧和氧气分子的结构以及蒸发后分子之间的作用力变化。同时,文章也给出了解题技巧,建议根据得分点的数量来合理分配答题时间。最后,文章提供了答案解析,标注了每个得分点的位置。 ... [详细]
  • 本文介绍了C++中省略号类型和参数个数不确定函数参数的使用方法,并提供了一个范例。通过宏定义的方式,可以方便地处理不定参数的情况。文章中给出了具体的代码实现,并对代码进行了解释和说明。这对于需要处理不定参数的情况的程序员来说,是一个很有用的参考资料。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 判断数组是否全为0_连续子数组的最大和的解题思路及代码方法一_动态规划
    本文介绍了判断数组是否全为0以及求解连续子数组的最大和的解题思路及代码方法一,即动态规划。通过动态规划的方法,可以找出连续子数组的最大和,具体思路是尽量选择正数的部分,遇到负数则不选择进去,遇到正数则保留并继续考察。本文给出了状态定义和状态转移方程,并提供了具体的代码实现。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文介绍了Python异常的捕获、传递与抛出操作,并提供了相关的操作示例。通过异常的捕获和传递,可以有效处理程序中的错误情况。同时,还介绍了如何主动抛出异常。通过本文的学习,读者可以掌握Python中异常处理的基本方法和技巧。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
author-avatar
哗锅_348
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有