贪心算法part03算法

这篇具有很好参考价值的文章主要介绍了贪心算法part03算法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

贪心算法part03

● 1005.K次取反后最大化的数组和
● 134. 加油站
● 135. 分发糖果

1.leetcode 1005.K次取反后最大化的数组和

https://leetcode.cn/problems/maximize-sum-of-array-after-k-negations/description/

class Solution {
    public int largestSumAfterKNegations(int[] nums, int k) {
        //每次我都取最小的元素进行取反,那所有的不就最大吗
        while(k>0){
            k--;
            //找出最小值的下标
            int index=findMinIndex(nums);
            //改变该值(进行取反)
            nums[index]=-nums[index];
        }
        //整个数组再进行求和
        int result=0;
        for(int i=0;i<nums.length;i++){
            result+=nums[i];
        }
        return result;
        
    }
    public int findMinIndex(int[] nums){
        //记录最小值的下标
        int index=0;
        int min=nums[0];
        for(int i=1;i<nums.length;i++){
            if(min<nums[i]){
                min=min;
                index=index;
            }else{
                min=nums[i];
                index=i;
            }
        }
        return index;
    }
}

2.leetcode 134. 加油站

https://leetcode.cn/problems/gas-station/description/

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;
    }
}

3.leetcode 135. 分发糖果

https://leetcode.cn/problems/candy/description/文章来源地址https://www.toymoban.com/news/detail-800039.html

class Solution {
    public int candy(int[] ratings) {
        //每个孩子至少分配到 1 个糖果。
        //相邻两个孩子评分更高的孩子会获得更多的糖果(左右两边分别得比较,分两步去处理)
        
        //定义一个糖果数量数组,每个下标对应每个孩子,每个元素对应糖果数量
        int result=0;
        int[] candy=new int[ratings.length];
        candy[0]=1;
        //都初始化为为1
        // for(int i=0;i<candy.length;i++){
        //     candy[i]=1;
        // }
        //数组从左往右:右边孩子比左边孩子得分高
        for(int i=1;i<ratings.length;i++){
            if(ratings[i]>ratings[i-1]){
                //提高右边孩子的值(是左边孩子的+1)
                candy[i]=candy[i-1]+1;
            }else{
                candy[i]=1;
            }
        }
        //数组从右往左:左边孩子比右边孩子的得分高
        for(int i=ratings.length-2;i>=0;i--){
            if(ratings[i]>ratings[i+1]){
                //在原来的,和现在在右边孩子的+1中取最大值
                candy[i]=Math.max(candy[i],candy[i+1]+1);
            }
        }
        //计算糖果数量
        for(int i=0;i<candy.length;i++){
            result+=candy[i];
        }
        return result;
    }
}

到了这里,关于贪心算法part03算法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构与算法之贪心&动态规划

            一:思考         1.某天早上公司领导找你解决一个问题,明天公司有N个同等级的会议需要使用同一个会议室,现在给你这个N个会议的开始和结束 时间,你怎么样安排才能使会议室最大利用?即安排最多场次的会议?电影的话 那肯定是最多加票价最高的,入场

    2024年02月09日
    浏览(47)
  • 【夜深人静学习数据结构与算法 | 第六篇】贪心算法

    目录 前言: 引入: 贪心算法:     455. 分发饼干 - 力扣(LeetCode) 376. 摆动序列 - 力扣(LeetCode) 53. 最大子数组和 - 力扣(LeetCode) 122. 买卖股票的最佳时机 II - 力扣(LeetCode)         在本文我们将为大家介绍在计算机中比较常见的一种算法:贪心算法。他并没有具体的代

    2024年02月09日
    浏览(53)
  • 数据结构与算法----复习Part 8 (链表双指针)

    本系列是算法通关手册LeeCode的学习笔记 算法通关手册(LeetCode) | 算法通关手册(LeetCode) (itcharge.cn) 本系列为自用笔记,如有版权问题,请私聊我删除。 目录 一,双指针简介(Two Pointers) 二,起点不一致的快慢指针 三,步长不一致的快慢指针 判断链表中是否含有环: 四

    2024年02月19日
    浏览(60)
  • 【贪心算法Part03】| 1005.K次取反后最大化的数组和、134.加油站、135.分发糖果

    目录 🎈LeetCode1005.K次取反后最大化的数组和  🎈LeetCode134.加油站 🎈LeetCode135.分发糖果 链接:1005.K次取反后最大化的数组和 给你一个整数数组  nums  和一个整数  k  ,按以下方法修改该数组: 选择某个下标  i  并将  nums[i]  替换为  -nums[i]  。 重复这个过程恰好  k  次

    2024年02月16日
    浏览(44)
  • 新星计划Day6【数据结构与算法】 链表Part2

    👩‍💻博客主页:京与旧铺的博客主页 ✨欢迎关注🖱点赞🎀收藏⭐留言✒ 🔮本文由京与旧铺原创,csdn首发! 😘系列专栏:java学习 💻首发时间:🎞2022年4月30日🎠 🎨你做三四月的事,八九月就会有答案,一起加油吧 🀄如果觉得博主的文章还不错的话,请三连支持一

    2023年04月08日
    浏览(60)
  • 数据结构和算法-2023.07.03

      由于工作量加大,加之每天要写博客的内容上,深度可能没有那么深度了,但是为了保持这个日更的习惯,还是要坚持更新一些,我也发现了,其实写这个博文,更让我从某种程度上我重新的安静下来,重新的去理解和审视之前学习过的知识,之前的薄弱点在哪里,即使在

    2024年02月12日
    浏览(46)
  • 【地铁上的面试题】--基础部分--数据结构与算法--动态规划和贪心算法

    一、动态规划的基本概念和思想 1.1 动态规划的定义和特点 动态规划是一种解决多阶段决策问题的算法思想,它通过将问题划分为若干个子问题,并保存子问题的解来求解原问题的方法。动态规划的特点包括以下几个方面: 最优子结构性质:动态规划问题具有最优子结构,即

    2024年02月12日
    浏览(58)
  • Day34 贪心算法 part03 1005. K 次取反后最大化的数组和 134. 加油站 135. 分发糖果

    思路 第一步,从前向后遍历,遇到负数将其变为正数,同时K– 第二步:如果K还大于0,那么反复转变数值最小的元素,将K用完 第三步:求和 方法一(暴力) leetcode超时(35/40) 方法二(贪心)

    2024年01月19日
    浏览(42)
  • 算法分析与设计考前冲刺 (算法基础、数据结构与STL、递归和分治、 动态规划、贪心算法、 回溯算法)

    算法分析与设计考前冲刺 算法基础 算法是一系列解决问题的清晰指令,代表着用系统的方法描述解决问题的策略机制。 程序是算法用某种程序设计语言的具体的 具体实现 算法特征: 有穷性(有限步) 确定性 输入 输出 可行性(有限时间) 算法的复杂性: 时间复杂性 和空间复

    2024年02月02日
    浏览(44)
  • 第八章 贪心算法 part03 1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果 (day34补)

    给你一个整数数组 nums 和一个整数 k ,按以下方法修改该数组: 选择某个下标 i  并将 nums[i] 替换为 -nums[i] 。 重复这个过程恰好 k 次。可以多次选择同一个下标 i 。 以这种方式修改数组后,返回数组 可能的最大和 。 示例 1: 示例 2: 示例 3: 提示: 1 = nums.length = 104 -100

    2024年02月11日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包