当前位置: 首页 > article >正文

Python应用算法之贪心算法理解和实践

一、什么是贪心算法?

贪心算法(Greedy Algorithm)是一种简单而高效的算法设计思想,其核心思想是:在每一步选择中,都采取当前状态下最优的选择(即“局部最优解”),希望通过一系列局部最优解最终达到全局最优解。虽然贪心算法并不总是能得到全局最优解,但在许多问题中,它能够快速找到近似最优解。

1. 贪心算法的优缺点

优点

  • 高效性:通常时间复杂度较低,适合解决大规模问题。
  • 简单性:实现简单,易于理解和应用。
  • 实用性:在许多实际问题中(如调度、路径规划等),贪心算法能快速找到近似最优解。

缺点

  • 局限性:贪心算法并不总是能得到全局最优解。
  • 适用范围有限:需要满足贪心选择性质和最优子结构性质。

2. 贪心算法的适用场景

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

  • 贪心选择性质:可以通过局部最优选择逐步构造全局最优解。
  • 最优子结构:问题的最优解可以通过子问题的最优解构造。
  • 如果不满足上述条件,贪心算法可能无法得到正确结果。例如,在某些情况下,动态规划可能是更好的选择。

二、贪心算法经典问题与解法

1. 贪心算法的核心思想

贪心算法的特点可以总结为以下几点:
(1)局部最优选择
在每一步决策时,选择当前看起来最优的选项。
不考虑未来的后果,也不回溯之前的决策。
(2)无后效性
一旦做出某个选择,就不会再改变。
每一步的决策只依赖于当前状态,而不依赖于之前的状态。
(3)贪心选择性质
全局最优解可以通过一系列局部最优选择来构造。
(4)最优子结构性质
问题的最优解包含其子问题的最优解。

2. 经典贪心算法示例

2.1 活动选择问题

问题描述:
给定一组活动,每个活动有开始时间和结束时间,要求选择尽可能多的互不冲突的活动。
算法描述:
按活动的结束时间排序。
每次选择最早结束的活动,并排除与之冲突的活动。
代码实现:

def activity_selection(start, finish):# 按结束时间排序activities = sorted(zip(start, finish), key=lambda x: x[1])selected = []last_finish_time = -1for start_time, finish_time in activities:if start_time >= last_finish_time:  # 如果活动不冲突selected.append((start_time, finish_time))last_finish_time = finish_timereturn selected# 调用函数
start_times = [1, 3, 0, 5, 8, 5]
finish_times = [2, 4, 6, 7, 9, 9]
print("Selected activities:", activity_selection(start_times, finish_times))

2.2 分数背包问题(Fractional Knapsack Problem)

问题描述:
给定一组物品,每个物品有重量和价值,要求在不超过背包容量的情况下,最大化总价值。允许将物品分割。
算法描述:
计算每个物品的单位价值(价值/重量)。
按单位价值从高到低排序。
尽量装入单位价值最高的物品,直到背包装满。
代码实现:

def fractional_knapsack(weights, values, capacity):# 计算单位价值并排序items = sorted([(v / w, w, v) for v, w in zip(values, weights)],key=lambda x: x[0],reverse=True)total_value = 0for value_per_weight, weight, value in items:if capacity >= weight:total_value += valuecapacity -= weightelse:total_value += value_per_weight * capacitybreakreturn total_value# 调用函数
weights = [10, 20, 30]
values = [60, 100, 120]
capacity = 50
print("Maximum value:", fractional_knapsack(weights, values, capacity))

3. 贪心算法刷力扣题

3.1 无重叠区间(LeetCode原题435题)

问题描述
给定一个区间的集合 intervals,其中 intervals[i] = [start_i, end_i],返回需要移除的最小区间数量,使得剩余区间互不重叠。
解题思路:
按区间的结束时间排序。
每次选择最早结束的区间,并移除与之重叠的区间。
代码实现:

def eraseOverlapIntervals(intervals):if not intervals:return 0intervals.sort(key=lambda x: x[1])  # 按结束时间排序count = 0end = intervals[0][1]for i in range(1, len(intervals)):if intervals[i][0] < end:  # 当前区间与前一个区间重叠count += 1else:end = intervals[i][1]  # 更新结束时间return count
# 调用函数
intervals = [[1, 2], [2, 3], [3, 4], [1, 3]]
print(eraseOverlapIntervals(intervals))  
# 输出: 1

3.2 跳跃游戏(LeetCode 原题55题)

问题描述:
给定一个非负整数数组 nums,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个位置。
解题思路:
维护一个变量 max_reach 表示当前能到达的最远位置。
遍历数组时,更新 max_reach,如果当前位置超过了 max_reach,则无法到达终点。
代码实现:

def canJump(nums):max_reach = 0for i, jump in enumerate(nums):if i > max_reach:  # 当前位置不可达return Falsemax_reach = max(max_reach, i + jump)return max_reach >= len(nums) - 1# 调用函数
nums = [2, 3, 1, 1, 4]
print(canJump(nums))  
# 输出: True

4. 优化方法

4.1 数据预处理

(1)排序
贪心算法通常依赖于某种顺序(如活动的结束时间、物品的单位价值等),因此对数据进行适当的排序是关键。
使用高效的排序算法(如快速排序或归并排序)可以减少预处理的时间开销。
(2)去重或过滤
在某些情况下,可以通过去重或过滤无效数据来减少计算量。

4.2 使用优先队列优化选择过程

当需要动态选择当前最优元素时,可以使用优先队列(如最小堆或最大堆)来加速选择过程。

4.3 并行化与分布式计算

对于独立的子问题,可以使用多线程或多进程并行处理。

4.4 近似算法优化

(1)放松约束条件
在某些情况下,可以通过放松约束条件来简化问题,从而使贪心算法更高效。
例如,在分数背包问题中,允许分割物品可以显著简化问题。
(2)局部搜索优化
在贪心算法的基础上,可以通过局部搜索(如交换相邻元素)进一步优化结果。
示例:任务调度问题
使用贪心算法生成初始调度方案后,通过交换任务顺序来减少总完成时间。

三、总结

贪心算法,名思义,总是做出当前的最优选择,即期望通过局部的最优选择获得整体的最优选择。
某种意义上说,贪心算法是很贪婪、很目光短浅的,它不从整体考虑,仅仅只关注当前的最大利益,所以说它做出的选择仅仅是某种意义上的局部最优,但是贪心算法在很多问题上还是能够拿到最优解或较优解。

1. 注意事项

(1)适用条件:问题需满足贪心选择性质(局部最优可推导全局最优)和最优子结构。例如,分数背包满足贪心性质,而0-1背包不满足。
(2)验证必要性:贪心策略的正确性需通过数学归纳法或反证法严格证明。

相关文章:

Python应用算法之贪心算法理解和实践

一、什么是贪心算法&#xff1f; 贪心算法&#xff08;Greedy Algorithm&#xff09;是一种简单而高效的算法设计思想&#xff0c;其核心思想是&#xff1a;在每一步选择中&#xff0c;都采取当前状态下最优的选择&#xff08;即“局部最优解”&#xff09;&#xff0c;希望通…...

Docker 性能优化指南

Docker 提供了强大的容器化功能&#xff0c;能够帮助开发者在不同的环境中构建、测试和部署应用。然而&#xff0c;随着容器化应用的不断增长&#xff0c;Docker 容器可能会面临一些性能瓶颈&#xff0c;影响其运行效率、资源占用和扩展能力。为了确保容器在生产环境中的高效运…...

STM32MP157A单片机移植Linux驱动深入版

需求整理 在Linux设备树中新增leds节点&#xff0c;其有3个gpio属性&#xff0c;分别表示PE10对应led1&#xff0c;PF10对应led2&#xff0c;PE8对应led3&#xff0c;设备树键值对如下&#xff1a; leds { led1-gpio <&gpioe 10 0>; led2-gpio &l…...

NLP在市场情报分析中的应用:解析数据驱动的营销新时代

NLP在市场情报分析中的应用:解析数据驱动的营销新时代 在当今信息爆炸的时代,市场情报分析已成为企业决策和市场策略的重要工具。自然语言处理(Natural Language Processing, NLP)作为人工智能领域的一个重要分支,为市场情报分析带来了全新的可能。作为人工智能和Python领…...

[大模型笔记]扣子-知识库搭建,并用Java-SDK调用的笔记

记录一下学习coze官方提供的java-sdk的过程 官方参考文档 一、搭建知识库 1、登录coze后&#xff0c;点击工作空间-资源库&#xff0c;点击右上角的资源&#xff0c;点击知识库 2、输入知识库名词以及知识库的描述 3、选择要上传的文档类型&#xff0c;点击创建并导入&…...

Unity学习笔记-Unity了解,安装,简单配置(一)

Unity 是什么&#xff1f; Unity 是一款广受欢迎的跨平台游戏开发引擎&#xff0c;由 Unity Technologies 公司开发并推出。它以强大的功能和易用性&#xff0c;在游戏开发领域占据着举足轻重的地位&#xff0c;甚至可以说&#xff0c;它改变了游戏开发的格局。凭借其出色的跨…...

LLaMA-Factory|微调大语言模型初探索(3),qlora微调deepseek记录

前言 上篇文章记录了使用lora微调llama-1b,微调成功,但是微调llama-8b显存爆炸,这次尝试使用qlora来尝试微调参数体量更大的大语言模型,看看64G显存的极限在哪里。 1.Why QLora? QLoRA 在模型加载阶段通过 4-bit 量化大幅减少了模型权重的显存占用。QLoRA 通过 反量化到 …...

手动配置 Yum 仓库

在我使用虚拟机&#xff0c;系统在尝试访问CentOS的镜像列表时遇到了网络问题&#xff0c;具体表现为无法解析mirrorlist.centos.org 于是手动配置yum仓库 备份现有的 repo 文件 sudo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 创建新…...

JEEWMS cgFormBuildController.do 方法mobileForm存在SQL注入

一:登录扫描 JeeWMS是一款免费开源的仓库管理系统,支持3PL和厂内物流,涵盖订单管理,仓储管理,计费管理,现场作业,RFID,AGV等功能。本文介绍了系统的简介,功能,安装,截图和链接,适合仓储企业和开发者参考。厦门市灵鹿谷科技有限公司JEEWMS jeecgFormDemoController…...

【二分搜索 C/C++】洛谷 P1873 EKO / 砍树

2025 - 02 - 19 - 第 55 篇 Author: 郑龙浩 / 仟濹(CSND) 【二分搜索】 文章目录 洛谷 P1873 EKO / 砍树题目描述输入格式输出格式输入输出样例 #1输入 #1输出 #1 输入输出样例 #2输入 #2输出 #2 说明/提示题目中的部分变量思路代码 洛谷 P1873 EKO / 砍树 题目描述 伐木工人…...

python面试题整理

Python 如何处理异常&#xff1f; Python中&#xff0c;使用try 和 except 关键字来捕获和处理异常 try 块中放置可能会引发异常的代码&#xff0c;然后在except块中处理这些异常。 能补充一下finally的作用吗&#xff1f; finally 块中的代码无论是否发生异常都会执行&#xf…...

深度学习之图像回归(二)

前言 这篇文章主要是在图像回归&#xff08;一&#xff09;的基础上对该项目进行的优化。&#xff08;一&#xff09;主要是帮助迅速入门 理清一个深度学习项目的逻辑 这篇文章则主要注重在此基础上对于数据预处理和模型训练进行优化前者会通过涉及PCA主成分分析 特征选择 后…...

中文Build a Large Language Model (From Scratch) 免费获取全文

中文pdf下载地址&#xff1a;https://pan.baidu.com/s/1aq2aBcWt9vYagT2-HuxdWA?pwdlshj 提取码&#xff1a;lshj 原文、代码、视频项目地址&#xff1a;https://github.com/rasbt/LLMs-from-scratch 翻译工具&#xff1a;沉浸式翻译&#xff08;https://app.immersivetrans…...

【鸿蒙开发】第四十四章 Map Kit(地图服务)

目录​​​​​​​ 1 Map Kit简介 1.1 场景介绍 2 开发准备 开通地图服务 3 创建地图 3.1 显示地图 3.1.1 接口说明 3.1.2 开发步骤 1、地图显示 2、设置地图属性 3、开启3D建筑图层 4、地图前后台切换 5、深色模式 3.2 切换地图类型 3.2.1 场景介绍 3.2.2 接…...

EasyExcel 自定义头信息导出

需求&#xff1a;需要在导出 excel时&#xff0c;合并单元格自定义头信息(动态生成)&#xff0c;然后才是字段列表头即导出数据。 EasyExcel - 使用table去写入&#xff1a;https://easyexcel.opensource.alibaba.com/docs/current/quickstart/write#%E4%BD%BF%E7%94%A8table%E…...

Angular 中获取 DOM 节点的几种方法

文章目录 1. 使用ViewChild获取单个 DOM 节点2. 使用ViewChildren获取多个 DOM 节点3. 使用ElementRef直接访问 DOM4. 使用Renderer2操作 DOM5. 总结 在 Angular 开发中&#xff0c;虽然框架鼓励我们通过组件和模板来操作 DOM&#xff0c;但在某些情况下&#xff0c;直接访问和…...

索引的优缺点与常见类型详解

索引是数据库优化的核心工具&#xff0c;但盲目使用可能适得其反。本文将系统梳理索引的缺点、常见类型及适用场景&#xff0c;助你避开常见陷阱。 一、索引的缺点 虽然索引能加速查询&#xff0c;但并非“免费午餐”&#xff0c;需警惕以下代价&#xff1a; 1. 存储空间开销…...

DeepSeek 提示词:定义、作用、分类与设计原则

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编…...

ubuntu环境编译ffmepg支持nvidia显卡加速

文章目录 1. 安装NVIDIA驱动2. 安装CUDA&NV-CODEC2.1 安装CUDA2.2 安装NV-CODEC 3. 编译ffmpeg3.1 安装依赖3.2 下载源码安装依赖3.3 验证 4. 使用 1. 安装NVIDIA驱动 安装依赖包 sudo apt install -y ubuntu-drivers-common编辑 /etc/modprobe.d/blacklist-nouveau.conf 文…...

淘宝商品评论API调用教程:轻松获取用户评价数据(含测试Key)

在电商开发中&#xff0c;用户评价数据是优化产品和提升用户体验的重要依据。淘宝提供了商品评论API&#xff0c;方便开发者获取商品的用户评价信息。本文将详细介绍如何调用淘宝商品评论API&#xff0c;并附上测试Key供调试使用。 一、准备工作 注册淘宝开放平台账号 前往注册…...

边缘安全加速(Edge Security Acceleration)

边缘安全加速&#xff08;Edge Security Acceleration&#xff0c;简称ESA&#xff09;是一种通过将安全功能与网络边缘紧密结合来提升安全性和加速网络流量的技术。ESA的目标是将安全措施部署到接近用户或设备的地方&#xff0c;通常是在网络的边缘&#xff0c;而不是将所有流…...

SpringCould+vue3项目的后台用户管理的CURD【Taurus教育平台】

文章目录 一.SpringCouldvue3项目的后台用户管理的CURD【Taurus教育平台】 1.1 背景 二.用户列表&#xff08;分页查询&#xff09; 2.1 前端Vue3 &#xff08;Vue3-Element-Admin&#xff09;2.2 后端SpringCould 处理 三. 用户信息删除 3.1 前端Vue3 &#xff08;Vue3-Eleme…...

ROS-相机话题-获取图像-颜色目标识别与定位-目标跟随-人脸检测

文章目录 相机话题获取图像颜色目标识别与定位目标跟随人脸检测 相机话题 启动仿真 roslaunch wpr_simulation wpb_stage_robocup.launch rostopic hz /kinect2/qhd/image_color_rect/camera/image_raw&#xff1a;原始的、未经处理的图像数据。 /camera/image_rect&#xff…...

破解Docker镜像拉取难题:为Docker配置代理加速镜像拉取

为Docker配置代理加速镜像拉取 概述守护进程配置&#xff08;推荐长期使用&#xff09;Systemd环境变量配置&#xff08;适合临时调整&#xff09;其他 概述 为什么需要配置代理与镜像加速? 跨国网络限制&#xff1a;境外镜像仓库拉取速度慢或无法访问企业安全策略&#xff…...

细分数字货币钱包的不同种类

文章目录 一、中心化钱包1.1 中心化钱包架构1.2 中心化钱包业务细节流程 二、去中心化钱包(HD 钱包)2.1 去中心化钱包架构2.2 去中心化钱包细节业务流程 三、硬件钱包3.1 硬件钱包架构3.2 硬件钱包细节业务流程 四、MPC 托管钱包五、多签钱包 中心化钱包 &#xff1a;钱包私钥一…...

推理模型时代:大语言模型如何从对话走向深度思考?

一、对话模型和推理模型的区别概述 对话模型是专门用于问答交互的语言模型,符合人类的聊天方式,返回的内容可能仅仅只是一个简短的答案,一般模型名称后面会带有「chat」字样。 推理模型是比较新的产物,没有明确的定义,一般是指输出过程中带有<think>和</think&…...

调用click.getchar()时Windows PyCharm无法模拟键盘输入

文章目录 问题描述解决方案参考文献 问题描述 调用 click.getchar() 时&#xff0c;Windows PyCharm 无法模拟键盘输入 解决方案 Run → Edit Configurations… → Modify options → Emulate terminal in output console 参考文献 Terminal emulator | PyCharm Documentati…...

关于ES中text类型时间字段范围查询的结构化解决方案

前言 有关es中text类型的时间字段范围查询的问题&#xff0c;比如&#xff1a; {"query": {"range": {"insertTime": {"gte": "2025-02-01T00:00:00","lte": "2025-11-30T23:59:59","format&quo…...

易基因: ChIP-seq+DRIP-seq揭示AMPK通过调控H3K4me3沉积和R-loop形成以维持基因组稳定性和生殖细胞完整性|NAR

原文&#xff1a;ChIP-seqDRIP-seq揭示AMPK通过调控H3K4me3沉积和R-loop形成以维持基因组稳定性和生殖细胞完整性&#xff5c;NAR 大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 在饥饿等能量胁迫条件下&#xff0c;生物体会通过调整…...

Web 自动化测试提速利器:Aqua 的 Web Inspector (检查器)使用详解

Web 自动化测试提速利器:Aqua 的 Web Inspector (检查器)使用详解 前言简介一、安装二、Web Inspector 的使用2.1 获取元素定位器(Locators)2.2 将定位器添加到代码2.3 验证定位器2.4 处理 Frames (框架)总结前言 JetBrains 的 Aqua IDE 提供强大的 Web Inspector 工具,帮…...