本文共 993 字,大约阅读时间需要 3 分钟。
题目的链接在这里:
你需要按照以下要求,帮助老师给这些孩子分发糖果:
每个孩子至少分配到 1 个糖果。
相邻的孩子中,评分高的孩子必须获得更多的糖果。 那么这样下来,老师至少需要准备多少颗糖果呢?代码如下:
class Solution { public int candy(int[] ratings) { //这里的贪心策略是 只看最近的,也就是只考虑并更新相邻一侧的大小关系 //这种贪心肯定是要找到对应的最小值,如果是找到最小的一个的话,首先是需要有一个方法能在不动 //数组的情况下,找到最小值,感觉这样就很浪费时间了,而且这题正常来说是一个不重复的数组吧 //就刚刚看了一个想到的,因为这个值有个条件是 每个孩子至少有一个,所以他们的起始点都是1个 //然后经过两次变量,首先从左往右,如果左边的比右边大的话,就把右边的那个值,思路出现了错误 //不能单单把res作为总数,还是需要用来设置为每个数组里的值 int res[]=new int[ratings.length]; int count=0; //先初始化全为1 for(int i=0;iratings[i]){ res[i+1]=(res[i]+1); } } //再从右往左,也就是比右边的,但这是在前面的先决条件执行,所以需要再由一个条件就是,当前的糖果数小于比他小的数 for(int j=ratings.length-1;j>0;j--){ if(ratings[j-1]>ratings[j]&&res[j-1]<=res[j]){ res[j-1]=(res[j]+1); } } //再统计最后的结果 for(int i=0;i
转载地址:http://bifen.baihongyu.com/