1005.K次取反后最大化的数组和
给你一个整数数组 nums
和一个整数 k
,按以下方法修改该数组:
- 选择某个下标
i
并将nums[i]
替换为-nums[i]
。
重复这个过程恰好 k
次。可以多次选择同一个下标 i
。
以这种方式修改数组后,返回数组 可能的最大和 。
class Solution {
public:
int largestSumAfterKNegations(vector<int>& nums, int k) {
sort(nums.begin(),nums.end());
for(int i = 0;i<k;i++)
{
if(i<nums.size()&&nums[i] < 0) nums[i] = -nums[i];
else
{
sort(nums.begin(),nums.end());
nums[0] = ((k-i)%2)?-nums[0]:nums[0];
break;
}
}
int sum = 0;
for(int i = 0;i<nums.size();i++)
{
cout<<nums[i]<<" ";
sum += nums[i];
}
return sum;
}
};
134. 加油站
在一条环路上有 n
个加油站,其中第 i
个加油站有汽油 gas[i]
升。
你有一辆油箱容量无限的的汽车,从第 i
个加油站开往第 i+1
个加油站需要消耗汽油 cost[i]
升。你从其中的一个加油站出发,开始时油箱为空。
给定两个整数数组 gas
和 cost
,如果你可以按顺序绕环路行驶一周,则返回出发时加油站的编号,否则返回 -1
。如果存在解,则 保证 它是 唯一 的。
//暴力解但超时
class Solution {
public:
int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {
for(int i = 0;i<gas.size();i++)
{
int num = gas[i] - cost[i];;
int j = (i+1)%gas.size();
while(num>0&&j != i)
{
num += gas[j] - cost[j];;
j = (j+1)%gas.size();
}
if(j == i&&num>=0) return i;
}
return -1;
}
};
135. 分发糖果
n
个孩子站成一排。给你一个整数数组 ratings
表示每个孩子的评分。
你需要按照以下要求,给这些孩子分发糖果:
- 每个孩子至少分配到
1
个糖果。 - 相邻两个孩子评分更高的孩子会获得更多的糖果。
请你给每个孩子分发糖果,计算并返回需要准备的 最少糖果数目 。
class Solution {
public:
int candy(vector<int>& ratings) {
int l = ratings.size(),result = 0;
vector<int> give(l,1);
for(int i = 1;i<l;i++)
{
if(ratings[i]>ratings[i-1]) give[i] = give[i-1] + 1;
}
for(int i = l-1;i>0;i--)
{
if(ratings[i-1]>ratings[i]) give[i-1] = max(give[i] + 1,give[i-1]);
}
for(int i = 0;i<l;i++) result += give[i];
return result;
}
};