1005. K 次取反后最大化的数组和 - 力扣(LeetCode)
秒了
class Solution {
public int largestSumAfterKNegations(int[] nums, int k) {
Arrays.sort(nums);
// -4 -3 -2 -1 5
//-2 -2 0 2 5
int last = -1;
for(int i = 0;i<nums.length;i++){
if(k==0) break;
if(nums[i]<0){
k--;
nums[i]=-nums[i];
continue;
}
if(nums[i]>=0){
break;
}
}
Arrays.sort(nums);
if(k%2==1) nums[0]*=-1;
// while(k-->0){
// nums[0] = - nums[0];
// }
int res = 0;
for(int i = 0;i<nums.length;i++){
res += nums[i];
}
return res;
}
}
这个图,就是假设curSum之前选择,有可能让这个curSum>0的话,
那么假设中间开始,
从最左到最右已经确定和小于0,假设从中间到最右,和大于0
那么总体小于0,那么区间1就是<0,,这个节点就不能用了。要更新。
所以:一遇到累加和curSum<0.区间start==i+1就可以了,curSum重新归0,
至于环的问题,total排除掉了没有结果的案例,也就是说,一定是有结果的
那么curSum之前没有结果,那么一定再后面,也就不需要环了
class Solution {
public int canCompleteCircuit(int[] gas, int[] cost) {
int curSum = 0;
int totalSum = 0;
int start = 0;
for(int i = 0;i<gas.length;i++){
curSum += gas[i]-cost[i];
totalSum += gas[i]-cost[i];
if(curSum<0){
start = i+1;
curSum = 0;
}
}
if(totalSum<0) return -1;
return start;
}
}
涉及到一个思想,就是想处理好一边再处理另一边,不要两边想着一起兼顾
第二次遍历的时候注意取最大值就可以了
class Solution {
public int candy(int[] ratings) {
int [] nums = new int[ratings.length];
for(int i = 0;i<nums.length;i++){
if(i==0){
nums[i]=1;
}
if(i>0&&ratings[i]>ratings[i-1]){
nums[i]=nums[i-1]+1;
}else{
nums[i]=1;
}
}
for(int i = ratings.length-2;i>=0;i--){
if(ratings[i]>ratings[i+1]){
nums[i] = Math.max(nums[i+1]+1,nums[i]);
}else{
// nums[i] = Math.max(1,nums[i]);
//不要这个else也可以
}
}
int res = 0;
for(int i = 0;i<nums.length;i++){
res+=nums[i];
}
return res;
}
}