【随想录】Day34—第八章 贪心算法 part03

目录

  • [题目1: 1005. K 次取反后最大化的数组和](#题目1: 1005. K 次取反后最大化的数组和)
    • [1- 思路](#1- 思路)
    • [2- 题解](#2- 题解)
      • [⭐ K 次取反后最大化的数组和 ------题解思路](#⭐ K 次取反后最大化的数组和 ——题解思路)
  • [题目2: 134. 加油站](#题目2: 134. 加油站)
    • [1- 思路](#1- 思路)
    • [2- 题解](#2- 题解)
      • [⭐ 加油站 ------题解思路](#⭐ 加油站 ——题解思路)
  • [题目3: 135. 分发糖果](#题目3: 135. 分发糖果)
    • [1- 思路](#1- 思路)
    • [2- 题解](#2- 题解)
      • [⭐ 分发糖果 ------题解思路](#⭐ 分发糖果 ——题解思路)

题目1: 1005. K 次取反后最大化的数组和


1- 思路

贪心思路

    1. 先对数组中的元素进行排序
    1. 遍历数组,如果 当前遍历的位置值 < 0 && k>0 直接变号,之后对 k 进行 --
    1. 如果不小于 0,此时需要先排序,判断 k 是否为奇数,如果是奇数直接对最小位进行取反
    1. 最终遍历数组求和

2- 题解

⭐ K 次取反后最大化的数组和 ------题解思路

java 复制代码
class Solution {
    public int largestSumAfterKNegations(int[] nums, int k) {
        Arrays.sort(nums);
        for(int i = 0 ; i < nums.length;i++){
            if(nums[i]<0 && k > 0){
                nums[i] = -nums[i];
                k--;
            }
        }
        Arrays.sort(nums);
        if(k%2==1){
            nums[0] = -nums[0];
        }
        
        int res = 0;
        for(int i:nums){
            res+=i;
        }
        return res;
    }
}

题目2: 134. 加油站


1- 思路

贪心 :每到一个站点后,此时是有补充有消耗的,关注点:当前还剩余多少油。
贪心思路

  • ① 求两个数组的差值,记录为curSum
  • ② 遍历 gas 数组
    • 如果 totalSum一直大于零可以直接遍历
    • 如果 totalSum 出现小于 0 的情况,此时 重置和从下一个起点为开始点进行遍历

代码实现

  • 1. 数据结构
    • curSum:统计从头开始每一站的剩余油量和
    • totalSum:对每站的剩余油量进行求和
    • satrt:记录每次遍历的起始站点下标
  • 2. 遍历 gas 数组
    • 此时如果 curSum > 0 此时 继续遍历,同时利用 totalSum记录和
    • 此时如果 curSum < 0 此时 重置 satrttotalSum
    • 最终如果 totalSum<0 则直接返回 -1 表示不能到达

2- 题解

⭐ 加油站 ------题解思路

java 复制代码
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){
                curSum = 0;
                start = i+1;
            }
        }
        if(totalSum<0) return -1;
        return start;
    }
}

题目3: 135. 分发糖果


1- 思路

贪心思路

  • ① 初始化分发情况数组
  • ② 从前向后遍历,此时判断右边比左边大的情况
  • ③ 从后向前遍历,此时判断左边比右边大的情况
  • 难点:从前往后遍历 先对 分发数组 初始化,此后 从后向前 遍历时,大的那个位置的值应该为 步骤② 和 步骤③中元素的最大值。

2- 题解

⭐ 分发糖果 ------题解思路

java 复制代码
class Solution {
    public int candy(int[] ratings) {
        int[] candies = new int[ratings.length];
        candies[0] = 1;

        for (int i = 1; i < ratings.length; i++) {
            if (ratings[i] > ratings[i - 1]) {
                candies[i] = candies[i - 1] + 1;
            }else{
                candies[i] = 1;
            }
        }

        for(int j = ratings.length-1;j>=1;j--){
            if(ratings[j]<ratings[j-1]){
                candies[j-1] = Math.max(candies[j]+1,candies[j-1]);
            }
        }

        int res = 0;
        for(int r:candies){
            res+=r;
        }
        return res;
    }
}

相关推荐
励志成为嵌入式工程师4 分钟前
c语言简单编程练习9
c语言·开发语言·算法·vim
捕鲸叉34 分钟前
创建线程时传递参数给线程
开发语言·c++·算法
A charmer39 分钟前
【C++】vector 类深度解析:探索动态数组的奥秘
开发语言·c++·算法
wheeldown1 小时前
【数据结构】选择排序
数据结构·算法·排序算法
观音山保我别报错2 小时前
C语言扫雷小游戏
c语言·开发语言·算法
TangKenny3 小时前
计算网络信号
java·算法·华为
景鹤3 小时前
【算法】递归+深搜:814.二叉树剪枝
算法
iiFrankie3 小时前
SCNU习题 总结与复习
算法
Dola_Pan4 小时前
C++算法和竞赛:哈希算法、动态规划DP算法、贪心算法、博弈算法
c++·算法·哈希算法
小林熬夜学编程5 小时前
【Linux系统编程】第四十一弹---线程深度解析:从地址空间到多线程实践
linux·c语言·开发语言·c++·算法