当前位置: 首页 > news >正文

建云购网站免费建立公司网站

建云购网站,免费建立公司网站,redux wordpress,整个网站全是图片做的优质博文:IT-BLOG-CN 一、题目 n个孩子站成一排。给你一个整数数组ratings表示每个孩子的评分。你需要按照以下要求,给这些孩子分发糖果: 【1】每个孩子至少分配到1个糖果。 【2】相邻两个孩子评分更高的孩子会获得更多的糖果。 请你给每个孩…

优质博文:IT-BLOG-CN

一、题目

n个孩子站成一排。给你一个整数数组ratings表示每个孩子的评分。你需要按照以下要求,给这些孩子分发糖果:
【1】每个孩子至少分配到1个糖果。
【2】相邻两个孩子评分更高的孩子会获得更多的糖果。
请你给每个孩子分发糖果,计算并返回需要准备的 最少糖果数目。

示例 1:
输入:ratings = [1,0,2]
输出:5
解释:你可以分别给第一个、第二个、第三个孩子分发2、1、2颗糖果。

示例 2:
输入:ratings = [1,2,2]
输出:4
解释:你可以分别给第一个、第二个、第三个孩子分发1、2、1颗糖果。第三个孩子只得到1颗糖果,这满足题面中的两个条件。

n == ratings.length
1 <= n <= 2 * 104
0 <= ratings[i] <= 2 * 104

二、代码

【1】两次遍历: 我们可以将「相邻的孩子中,评分高的孩子必须获得更多的糖果」这句话拆分为两个规则,分别处理。
左规则:ratings[i−1] < ratings[i]时,i号学生的糖果数量将比i−1号孩子的糖果数量多。
右规则:ratings[i] > ratings[i+1]时,i号学生的糖果数量将比i+1号孩子的糖果数量多。
我们遍历该数组两次,处理出每一个学生分别满足左规则或右规则时,最少需要被分得的糖果数量。每个人最终分得的糖果数量即为这两个数量的最大值。

具体地,以左规则为例:我们从左到右遍历该数组,假设当前遍历到位置i,如果有ratings[i−1] < ratings[i]那么i号学生的糖果数量将比i−1号孩子的糖果数量多,我们令left[i]=left[i−1] + 1即可,否则我们令left[i] = 1。在实际代码中,我们先计算出左规则left数组,在计算右规则的时候只需要用单个变量记录当前位置的右规则,同时计算答案即可。

class Solution {public int candy(int[] ratings) {// 1、定义left[]数组,计算每个小朋友符合左侧规则时,能获取到的糖果// 2、定义两个变量,第一个计算前一个小朋友的糖果,第二个计算总的糖果数量,从右侧开始计算if (ratings.length == 0) {return 0;}// 创建数组int[] left = new int[ratings.length];left[0] = 1;for(int i = 1; i < ratings.length; i++) {if (ratings[i] > ratings[i - 1]) {left[i] = left[i - 1] + 1;} else {left[i] = 1;}}// 先初始化最后一个小朋友的糖果int next = 1, count = Math.max(1, left[ratings.length - 1]);for(int i = ratings.length - 2; i >= 0; i--) {if (ratings[i] > ratings[i + 1]) {next += 1;} else {next = 1;}count += Math.max(next, left[i]);}return count;}
}

时间复杂度: O(2n)其中n是孩子的数量。我们需要遍历两次数组以分别计算满足左规则或右规则的最少糖果数量。
空间复杂度: O(n)其中n是孩子的数量。我们需要保存所有的左规则对应的糖果数量。

【2】常数空间遍历: 定义两个变量,第一个计算当前小朋友的糖果pre,第一个小朋友默认为1,第二个计算总的糖果数量count,如果时递增的,那么就比较简单,我们给pre+1,如果递减了,我们重置pre = 1即可。下面考虑两个特殊场景:
 ● 当pre=1时,开始递减时,我们需要再创建一个变量decr,来表示递减的次数,然后将其累积到count中,也就达到了将递减转化为递增的效果。
 ● 当递减的队列长度,超过了递减前小朋友的糖果时,我们需要对递减前的小朋友的糖果+n,例如下图: 从左侧遍历时,第三个小朋友应该是3个糖果,所以定义inc记录递减前小朋友的糖果,如果递减的糖果decr等于递减前的糖果inc,就需要对inc + 1

class Solution {public int candy(int[] ratings) {// 1、定义两个变量,第一个计算当前小朋友的糖果pre,第二个计算总的糖果数量count。// 2、左侧遍历时,如果时递减的情况,需要再创建一个变量,计算递减的次数 decr。// 3、特殊处理:递减的时候,如果我拥有的糖果和递减前小朋友的糖果个数相同时,需要++,举例:5321的时候,5有3个糖果,此时的3再递减中也会有5个糖果,所以就需要对5的糖果+1if (ratings.length == 0) {return 0;}// 先初始化最后一个小朋友的糖果int pre = 1, count = 1, decr = 0, inc = 1;for(int i = 1; i < ratings.length; i++) {if (ratings[i] >= ratings[i - 1]) {pre = ratings[i] == ratings[i - 1] ? 1 : pre + 1;;// 如果时递增的,当前递减序列结束decr = 0;count += pre;// pre表示当前小朋友用于的当过inc = pre;} else {// 如果开始了递减序列,我们就开始记录递减序列的长度decr++;// 递减的时候,如果我拥有的糖果和递减的小朋友的个数相同时,需要++,举例:5321的时候,5有3个糖果,此时的3再递减中也会有5个糖果,所以就需要对5+1if (inc == decr) {decr++;}// 重置糖果为1pre = 1;count += decr;}}return count;}
}

时间复杂度: O(n)其中n是孩子的数量。我们需要遍历两次数组以分别计算满足左规则或右规则的最少糖果数量。
空间复杂度: O(1)我们只需要常数的空间保存若干变量。

http://www.yayakq.cn/news/95810/

相关文章:

  • 手机网站模版下载网站建设1993seo
  • 网站正在建设中yuss西北建设有限公司官方网站
  • 宣传册制作网站aws wordpress 路径
  • 东莞网站建设-信科网络北京市建设集团有限公司
  • 响应式网站切图wordpress目录seo
  • 让别人做网站怎样才安全上海网站建设极简慕枫
  • 花钱让别人做的网站版权是谁的口碑好的镇江网站建设
  • 微信网站价格wordpress修改主题代码
  • 做龙之向导网站有用吗网站建设教程免费夕滋湖南岚鸿官网
  • 服务企业网站建设的IT装修网络公司
  • 怎么取网页视频网站元素中国未来巨型空间站
  • 旅游网站功能简介域名取消wordpress
  • 网站的建设公司简介站点推广
  • 建行网站会员公众号怎么做微网站吗
  • 用wordpress建站会不会显得水平差哪家网站做旅游攻略好
  • server 2008 r2搭建网站html网站开发语言
  • 网站实现留言功能龙岗网站建设报价
  • 网站代码优化有哪些建站流程网站上线
  • 推广型的网站怎么做网站设计作业
  • 小程序源码能直接用吗北京seo不到首页不扣费
  • 网站规划建设前期规划方案html5制作手机网站教程
  • 全新的手机网站设计wordpress微信登录插件免费
  • php企业门户网站模板电脑版商城网站建设
  • 国外网站注册个人域名备案完成了 可以改网站内容吗
  • 湖北seo整站优化找人做方案的网站
  • 如何解决网站兼容wordpress icon
  • 专业网站运营设计新华区网站建设
  • 学做网站推广要多久时间达州建网站
  • iis wordpress多站点手机网站生成小程序
  • 网站快照明天更新是什么情况哈尔滨企业建网站推广