15-贪心算法

server/2025/2/25 6:57:38/

一,定义

算法>贪心算法的核心思想

算法>贪心算法的特点是:

  1. 局部最优:在每一步选择中,都选择当前看起来最好的选项。

  2. 不可回退:一旦做出选择,就不再回头重新考虑。

  3. 希望全局最优:通过一系列局部最优的选择,最终达到全局最优。

算法>贪心算法并不一定能得到全局最优解,但在某些问题中,它可以高效地找到一个接近最优的解。


举个例子

假设你有以下硬币面值:1 元、5 元、10 元,现在需要凑出 18 元,如何使用最少的硬币?

算法>贪心算法的思路是:

  1. 每次都选择面值最大的硬币

  2. 先用 10 元,剩下 8 元。

  3. 再用 5 元,剩下 3 元。

  4. 最后用 3 个 1 元。

  5. 总共用了 5 个硬币(10 + 5 + 1 + 1 + 1)。

在这个例子中,算法>贪心算法得到了最优解。但需要注意的是,算法>贪心算法并不总是能得到最优解。比如,如果硬币面值是 1 元、4 元、5 元,要凑出 8 元:

  • 算法>贪心算法会选择 5 + 1 + 1 + 1,用了 4 个硬币。

  • 但实际上最优解是 4 + 4,只用 2 个硬币。


算法>贪心算法的适用场景

算法>贪心算法适用于满足以下条件的问题:

  1. 最优子结构:问题的最优解可以通过子问题的最优解推导出来。

  2. 贪心选择性质:每一步的局部最优选择能够导致全局最优解。

常见的算法>贪心算法应用场景包括:

  • 找零钱问题(如上面的硬币例子)。

  • 活动选择问题(选择最多的互不冲突的活动)。

  • 最小生成树问题(如 Kruskal 算法和 Prim 算法)。

  • 霍夫曼编码(用于数据压缩)。


算法>贪心算法的优缺点

优点:
  • 简单直观:容易理解和实现。

  • 高效:通常时间复杂度较低。

缺点:
  • 不一定得到全局最优解算法>贪心算法只能保证局部最优,不能保证全局最优。

  • 需要证明正确性:在使用算法>贪心算法时,通常需要证明它能够得到全局最优解。

二,举例

        1.最长连续递增序列:给定一个未经排序的整数数组,找到最长且连续递增的子序列,并返回该序列的长度。

public class demo01 {public static void main(String[] args) {System.out.println(findLength(new int[]{1,2,3,2,3,4,3,4,5,6,7}));}public static int findLength(int[] nums) {int start = 0;int max = 0;for (int i = 1; i < nums.length; i++) {if (nums[i] <= nums[i-1]) {start = i;}max=Math.max(max,i-start+1);}return max;}
}

        2.在柠檬水摊上,每一杯柠檬水的售价为5美元。顾客排队购买你的产品,一次购买一杯。

每位顾客只卖一杯柠檬水,然后向你付5美元、10美元或20美元。必须给每个顾客正确找零。注意,一开始你手头没有任何零钱,如果你能给每位顾客正确找零,返回为true,否则返回false。

public class demo01 {public static void main(String[] args) {System.out.println(change(new int[]{5,5,20}));}public static boolean change(int[] bills) {int five=0,ten=0;for(int i=0;i<bills.length;i++){if(bills[i]==5){five++;         //此时多了一张5块}else if(bills[i]==10){if(five==0){return false;}five--;ten++;}else{                   //来了一张20if(five>0&&ten>0){  //如果有5块和10块five--;ten--;}else if(five>=3){  //或者有三张以上的5块five-=3;}else {return false;}}}return true;}
}

        3.三角形的最大周长:给定一些正数(代表长度)组成的数组arr,返回由其中三个长度组成的、面积不为0的三角形的最大周长。如果不能形成任何面积不为0的三角形,返回0.

import java.util.Arrays;public class demo01 {public static void main(String[] args) {System.out.println(length(new int[]{3,6,2,3}));}public static int length(int[] nums) {Arrays.sort(nums);          //先排序for (int i = nums.length-1; i >=2; i--) {if (nums[i-1]+ nums[i-2]>nums[i]) {return nums[i-1]+nums[i-2]+nums[i];}}return 0;}
}


http://www.ppmy.cn/server/170500.html

相关文章

Chrome 浏览器(版本号49之后)‌解决跨域问题

谷歌浏览器解决跨域问题 如何查看 Chrome 浏览器版本号 打开 Chrome 浏览器点击右上角的三个点&#xff0c;打开“设置”页面 点击“关于Chrome” 查看版本号 解决跨域操作&#xff1a;windows系统为例 方法一&#xff1a;命令行启动方式&#xff08;最简单&#xff09; …

Java Set实现类面试题

Java Set实现类面试题 HashSet Q1: HashSet的实现原理是什么&#xff1f; HashSet是基于HashMap实现的&#xff0c;使用HashMap的key来存储元素&#xff0c;value统一使用一个Object对象。 public class HashSetPrincipleExample {// 模拟HashSet的基本实现public class Si…

FutureTask 和 CompletableFuture

FutureTask 和 CompletableFuture 是 Java 并发编程中用于处理异步任务的两种工具&#xff0c;但它们在功能和使用场景上有显著区别。以下是两者的主要对比&#xff1a; 1. FutureTask 定义&#xff1a;FutureTask 是 Future 接口的一个实现类&#xff0c;表示一个异步计算任务…

深入剖析:基于红黑树实现自定义 map 和 set 容器

&#x1f31f; 快来参与讨论&#x1f4ac;&#xff0c;点赞&#x1f44d;、收藏⭐、分享&#x1f4e4;&#xff0c;共创活力社区。&#x1f31f; 在 C 标准模板库&#xff08;STL&#xff09;的大家庭里&#xff0c;map和set可是超级重要的关联容器成员呢&#x1f60e;&#x…

DSP芯片C6678的SRIO及其中断跳转的配置

C6678SRIO读写测试门铃中断跳转测试 SRIO简述代码前言SRIO配置原始代码1.使能电源2.初始化SRIO回环修改 3.SRIO测试 Doorbell门铃中断1.初始化中断函数2.中断向量表建立3.中断向量表的链接 本博客基于创龙“678ZH产品线”的SRIO代码&#xff0c;部分参考于网友们的博客&#xf…

工业4G路由器实现电力领域监控视频数据无线传输

工业 4G 路由器在电力监控领域凭借强大网络连接能力&#xff0c;能适应不同网络环境&#xff0c;快速接入互联网。丰富接口可连接各类电力设备&#xff0c;具备工业级硬件设计&#xff0c;能在恶劣环境稳定运行&#xff0c;还有多重安全防护。在电力监控数据传输中&#xff0c;…

DeepSeek核心技术全景解析:架构革新与工程突破

一、颠覆性架构设计&#xff1a;混合专家系统&#xff08;DeepSeekMoE&#xff09; 架构创新原理 动态参数激活&#xff1a;每个Token仅激活37亿参数&#xff08;总参数量671B&#xff09;&#xff0c;通过细粒度专家划分&#xff08;256路由专家1共享专家&#xff09;实现&q…

Java 大视界 -- 总结与展望:Java 大数据领域的新征程与无限可能(96)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…