1005.K次取反后最大化的数组和 135. 分发糖果 134. 加油站
创始人
2024-05-14 14:12:03
0

1005.K次取反后最大化的数组和

我是暴力算出来的,看题解后知道了新的解法。

本题求的是将元素翻转k次后数组最大和,每个元素可重复翻转。

先将数组排序后,绝对值大的负数就在前面,优先翻转他们。因此排序后从前向后遍历数组,做k次改变,因此循环k次。

定义idx指向绝对值最小的元素,当数字都为正数时翻转绝对值最小的元素和的损失最小。

若还没有遍历到正数,则当前负数绝对值一定比后一个元素绝对值大。idx指向当前遍历的负数。

若遍历到最后一个负数,当前元素绝对值若大于正数绝对值,则修改正数的符号。让idx++指向那个正数。

循环k此后即为修改好的数组。

135. 分发糖果 

本题为分发糖果,每个孩子最少一个,若当前孩子得分大于左/右孩子,则糖果数也大于左/右孩子。若等于,则没有要求。

本题注意要分两次情况遍历数组,不能同时兼顾左右孩子

i从1开始,先和左孩子i-1比较,从前向后比较。

        注意:i=0没有左孩子,不用进行比较。

i从len-2,开始,再和右孩子i+1比较,从后向前比较。

        注意:i=len-1没有右孩子,当len-1大于len-2时,因为已经从左向右遍历过了,因此len-1的糖果值始终为len-2+1.若len-1小于len-2,则len-1糖果值始终为1。因此不用遍历len-1.

//倒数第二个孩子如果小于倒数第一个孩子大于倒数第三个孩子,那么在第一轮循环的时候就会定型。如果倒数第二个孩子大于倒数第一个孩子那么倒数第二个孩子的糖果值就是倒数第一个孩子糖果值加一。因此无论怎样倒数第一个孩子的糖果值都不会变。

134. 加油站

我自己写的暴力超时了,哈哈。

本题我没有想到的核心:若gas数组和大于cost数组和,那么一定能走完全程(其实不是很理解)

定义total记录gas和cost数组和之差,若total<0,return -1,不能走完一圈。

那么假设一定能走完一圈,定义cursum为前面的累加和,start作为起始位置。若[0,i]的累加和<0,说明i之前一定不能作为起始位置,继续累加cursum,start从i+1开始。最后返回start即可。

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...