class Solution {
public:
int jump(vector<int>& nums) {
int nextDistance = 0;
int curDistance = 0;
int result = 0;
if (nums.size() == 1) return 0;
for (int i = 0; i <= curDistance; i++) {
nextDistance = max(nextDistance, nums[i] + i);
if (i == curDistance) {
// 如果当前覆盖最远距离下标不是是集合终点,步数就加一,还需要继续走。
result ++;
curDistance = nextDistance;
// 如果当前覆盖最远距离下标就是是集合终点,步数不用加一,因为不能再往后走了。
if (nextDistance >= nums.size() - 1) break;
}
}
return result;
}
};
1005.K次取反后最大化的数组和
思路
第一次接触按照绝对值排序的题目,比较有意思
代码随想录
class Solution {
static bool cmp(int a, int b) {
return abs(a) > abs(b);
}
public:
int largestSumAfterKNegations(vector<int>& nums, int k) {
int reusult = 0;
// 1. 按照绝对值从大到小排列,先反转绝对值大的负数
sort(nums.begin(), nums.end(), cmp);
for (int i = 0; i < nums.size(); i++) {
if (nums[i] < 0 && k > 0) {
nums[i] *= -1;
k --;
}
}
if (k % 2 == 1) {
// 2. 此时数列已经是正整数数列了,且k剩余奇数次,反转最小的正数即可
nums[nums.size() - 1] *= -1;
}
for (auto it : nums) {
reusult += it;
}
return reusult;
}
};