15-贪心算法

一,定义

贪心算法的核心思想

贪心算法的特点是:

  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{                   //来了一张20
                if(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;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/972552.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Docker:3、在VSCode上安装并运行python程序或JavaScript程序

1.VSCode上安装并运行python程序&#xff1a; 1.1.安装Docker插件 1.2.新建自动化脚本DockerFile FROM python:3.-slim-buster WORKDIR /app COPY .. RUN pip3 install -r requirements.txt CMD ["python3", "app.py"]COPY <本地路径><目标…

MOS管炸了,PWM“死区”时间得了解一下

从字面上来看“死区”的意思就是&#xff1a;如果处于这个区&#xff0c;那就会出现“损坏”的现象&#xff0c;直白点&#xff0c;就是“禁区”&#xff01; 实际应用中&#xff0c;比如大功率设备的电机&#xff0c;还有变频器等驱动电路&#xff0c;多部分都是采用MOS管和IG…

idea-代码补全快捷键

文章目录 前言idea-代码补全快捷键1. 基本补全2. 类型匹配补全3. 后缀补全4. 代码补全 前言 如果您觉得有用的话&#xff0c;记得给博主点个赞&#xff0c;评论&#xff0c;收藏一键三连啊&#xff0c;写作不易啊^ _ ^。   而且听说点赞的人每天的运气都不会太差&#xff0c;…

保姆级教程:利用Ollama与Open-WebUI本地部署 DeedSeek-R1大模型

1. 安装Ollama 根据自己的系统下载Ollama&#xff0c;我的是Linux&#xff0c;所以我使用如下命令进行下载安装&#xff1a; curl -fsSL https://ollama.com/install.sh | sh2. 安装Open-WebUI 使用 Docker 的方式部署 open-webui &#xff0c;使用gpu的话按照如下命令进行 …

win10 系统 自定义Ollama安装路径 及模型下载位置

win10 系统 自定义Ollama安装路径 及模型下载位置 由于Ollama的exe安装软件双击安装的时候默认是在C盘&#xff0c;以及后续的模型数据下载也在C盘&#xff0c;导致会占用C盘空间&#xff0c;所以这里单独写了一个自定义安装Ollama安装目录的教程。 Ollama官网地址&#xff1…

以教代学——费曼学习法

本文是思维导图&#xff0c;算是费曼学习法精髓我的个人总结&#xff0c;如果条件允许的话可以去看看费曼自传性质的书&#xff0c;书名见文末。 《别闹了&#xff0c;费曼先生》&#xff1a;英文书名为《Surely Youre Joking, Mr. Feynman!》&#xff0c;这是一本自传性质的书…

JWT 令牌

目录 一、JWT 1、什么是JWT 2、JWT的组成 3、JJWT签发与验证token 1、创建token 2、解析token 3、设置过期时间 4、自定义claims 前言&#xff1a; 在现代Web应用和微服务架构中&#xff0c;用户身份验证和信息安全传输是核心问题。JSON Web Token&#xff08;J…

工控网络安全介绍 工控网络安全知识题目

31.PDR模型与访问控制的主要区别(A) A、PDR把对象看作一个整体 B、PDR作为系统保护的第一道防线 C、PDR采用定性评估与定量评估相结合 D、PDR的关键因素是人 32.信息安全中PDR模型的关键因素是(A) A、人 B、技术 C、模型 D、客体 33.计算机网络最早出现在哪个年代(B) A、20世…

快速定位并优化CPU 与 JVM 内存性能瓶颈

1. CPU 性能优化实战 CPU&#xff08;Central Processing Unit&#xff09;是计算机系统的运算和控制核心&#xff0c;是信息处理、程序运行的最终执行单元&#xff0c;相当于系统的“大脑”。当 CPU 过于繁忙&#xff0c;就像“人脑”并发处理过多的事情&#xff0c;会降低做…

Kimi K1.5 与 DeepSeek R1:AI 模型的深度对比

文章目录 一、背景介绍二、核心功能对比三、K1.5 使用方法&#xff1a;四、总结 随着人工智能技术的飞速发展&#xff0c;大型语言模型在各个领域都展现出了巨大的潜力。Kimi K1.5 和 DeepSeek R1 作为当前备受关注的两款先进 AI 模型&#xff0c;各自拥有独特的功能和优势。本…

机器学习-生命周期

假如一个用户向银行申请贷款&#xff0c;银行该如何对这个用户进行评估?很明显&#xff0c;银行首先需要调查清楚该用户的资金储备情况和信用历史等&#xff0c;然后再决定是否向其放款。 整个机器学习生命周期如下图所示&#xff1a; 1、定义问题 在使用机器学习中的术语表…

Leetcode:学习记录(二)

按照https://leetcode.cn/circle/discuss/RvFUtj/顺序刷题 零、经验记录 1. 学会画图分析 2. 学会找终止条件 3. 做一道就高质量完成 一、二分算法 0. 总结&#xff1a;大于某个数的第一个数的位置有固定模板&#xff0c;其中要讨论最后一个数小于等于目标数的情况 1. 二…

Elasticsearch AI Assistant 集成 DeepSeek,1分钟搭建智能运维助手

作者&#xff1a;来自阿里云 - 魏子珺 简介&#xff1a; Elasticsearch 新支持 DeepSeek 系列模型&#xff0c;使用 AI 助手&#xff0c;通过自然语言交互&#xff0c;为可观测性分析、安全运维管理及数据智能处理提供一站式解决方案。 一、Elasticsearch AI Assistant 介绍 E…

DeepSeek操作Excel,实现图表自动化生成

案例 让DeepSeek操作Excel&#xff0c;实现图表自动化生成。我们只要用自然语言输入我们的需求&#xff08;根据哪块单元格区域做什么图表&#xff09;&#xff0c;就可以直接在Excel中自动生成图表。 操作主界面和图表效果 设置接入方式 这里提供了多种接入方式将DeepSeek接…

在 .NET 8/9 中使用 AppUser 进行 JWT 令牌身份验证

文章目录 一、引言二、什么是 JSON Web 令牌&#xff1f;三、什么是 JSON Web 令牌结构&#xff1f;四、设置 JWT 令牌身份验证4.1 创建新的 .NET 8 Web API 项目4.2 安装所需的 NuGet 软件包4.3 创建 JWT 配置模型4.4 将 JWT 配置添加到您的 appsettings.json 中4.5 为 Config…

【R语言】主成分分析与因子分析

一、主成分分析 主成分分析&#xff08;Principal Component Analysis, PCA&#xff09;是一种常用的无监督数据降维技术&#xff0c;广泛应用于统计学、数据科学和机器学习等领域。它通过正交化线性变换将&#xff08;高维&#xff09;原始数据投影到一个新的坐标系&#xff…

linux下pip下载项目失败

想下载CLIP的项目复现代码的时候&#xff0c;出现问题如下&#xff1a; 于是手动使用 Git 克隆仓库&#xff0c; git clone https://github.com/openai/CLIP.git cd CLIP pip install .ls查看文件如下&#xff1a;(手动克隆git项目成功)

Windows桌面系统管理8:项目实施

Windows桌面系统管理0&#xff1a;总目录-CSDN博客 Windows桌面系统管理1&#xff1a;计算机硬件组成及组装-CSDN博客 Windows桌面系统管理2&#xff1a;VMware Workstation使用和管理-CSDN博客 Windows桌面系统管理3&#xff1a;Windows 10操作系统部署与使用-CSDN博客 Wi…

【JavaScript】实战案例-放大镜效果、图片切换

目录 实现这种图片切换的和放大镜的效果&#xff1a; 第一步&#xff1a;图片的切换 第二步&#xff1a;鼠标经过中等盒子&#xff0c;显示隐藏大盒子 第三步&#xff1a;黑色遮罩盒子跟着鼠标来移动 遮罩层盒子移动的坐标&#xff1a; 总结一下~本章节对我有很大的收获…

windows使用clion运行lua文件,并且使用cjson

需要文件&#xff1a;clion&#xff0c;lua-5.4.2_Win64_bin&#xff0c;lua-5.4.2_Win64_dllw6_lib&#xff0c;lua-cjson-2.1.0.9&#xff0c;mingw64 1&#xff0c;下载安装clion。 2&#xff0c;下载lua windows运行程序 lua官网&#xff1a;http://www.lua.org/download…