代码随想录算法训练营第二十一天 | Javascript | 力扣Leetcode | 贪心 | 1005. K次取反后最大化的数组和、134. 加油站

目录

前言

简介

[题目链接:1005. K次取反后最大化的数组和](#题目链接:1005. K次取反后最大化的数组和)

[题目链接:134. 加油站](#题目链接:134. 加油站)


前言

踏平坎坷成大道,斗罢艰险又出发!

自律的尽头是自控,自控的尽头是硬控

愿道友们披荆斩棘,终能得偿所愿。

简介

本人是小几年经验的前端开发,算法基础只有力扣几十道题,非常薄弱。

今天是个人的代码随想录算法硬控自己第22天,继续贪心。

贪心妙啊!

题目链接:1005. K次取反后最大化的数组和
javascript 复制代码
/**
 * @param {number[]} nums
 * @param {number} k
 * @return {number}
 */
var largestSumAfterKNegations = function (nums, k) {
    nums.sort((a, b) => a - b);
    let res = 0, index = -1;
    // 贪心思路:先由小到大处理负数,逐个变正
    for (let i = 0; i < nums.length; i++) {
        if (nums[i] < 0 && k > 0) {
            nums[i] *= -1;
            k--;
        }
        if (k <= 0) break;
    }
    // 如果k>0,那么此时nums里必定都是非负的
    // 只需再从小到大排序且对第一个元素也就是最小值判断正负即可  
    if (k > 0) {
        nums.sort((a, b) => a - b);
        nums[0] = k % 2 === 1 ? -nums[0] : nums[0];
    }
    for (let i = 0; i < nums.length; i++) res += nums[i];

    return res;
};
题目链接:134. 加油站
javascript 复制代码
/**
 * @param {number[]} gas
 * @param {number[]} cost
 * @return {number}
 */
var canCompleteCircuit = function (gas, cost) {
    let currSum = 0, totalSum = 0, start = 0;
    for (let i = 0; i < gas.length; i++) {
        currSum += (gas[i] - cost[i]);
        totalSum += (gas[i] - cost[i]);
        if (currSum < 0) {
            start = i + 1;
            currSum = 0;
        }
    }
    if (totalSum < 0) return -1;
    return start;
};
相关推荐
啊森要自信6 小时前
CANN ops-cv:AI 硬件端视觉算法推理训练的算子性能调优与实战应用详解
人工智能·算法·cann
仟濹7 小时前
算法打卡day2 (2026-02-07 周五) | 算法: DFS | 3_卡码网99_计数孤岛_DFS
算法·深度优先
驭渊的小故事7 小时前
简单模板笔记
数据结构·笔记·算法
YuTaoShao7 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头7 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa7 小时前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior7 小时前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
Σίσυφος19008 小时前
PCL法向量估计 之 RANSAC 平面估计法向量
算法·机器学习·平面
xhbaitxl8 小时前
算法学习day39-动态规划
学习·算法·动态规划
I_LPL8 小时前
day23 代码随想录算法训练营 回溯专题2
算法·hot100·回溯算法·求职面试