吃肉的刷题记录2-贪心

文章目录

  • 贪心
    • 贪心算法的特点:
    • 贪心算法的应用场景:
    • 贪心算法的设计步骤:
    • 实现注意事项:
  • 例题: leetcode.322.零钱兑换
  • 例题: leetcode 5.最长回文字符串


贪心

贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择策略,以便产生全局最优解的算法思想。这种局部最优的选择通常基于某种特定的度量标准,它试图通过一系列最佳选择来构建最终的解决方案。

贪心算法的特点:

  1. 局部最优选择:在问题求解的每一步中,总是做出在当前看来最好的选择。
  2. 无回溯:所做的选择一旦确定,就不会改变,即算法不会回头去修正之前的选择。
  3. 简单高效:通常比其他算法(如动态规划或分治法)更容易理解和实现。
  4. 不总是得到全局最优解:贪心算法并不总是能得到全局最优解,只有当问题具有贪心选择性质和最优子结构性质时才适用。

贪心算法的应用场景:

  • 活动选择问题:选择尽可能多的不冲突的活动。
  • 霍夫曼编码:用于数据压缩,构建最优前缀码。
  • 最小生成树:如普里姆算法(Prim’s algorithm)和克鲁斯卡尔算法(Kruskal’s algorithm)。
  • Dijkstra算法:寻找图中单源最短路径。
  • 分数背包问题:允许物品分割的问题。

贪心算法的设计步骤:

  1. 证明最优子结构:证明问题可以分解为子问题,并且子问题的解也是最优的。
  2. 定义一个选择性质:定义一种策略,使得每次选择都是局部最优的。
  3. 证明贪心选择:证明局部最优选择能够导致全局最优解。
  4. 构造贪心算法:基于贪心选择性质设计算法。
  5. 证明正确性:通过数学归纳法或其他方式证明算法的正确性。

实现注意事项:

  • 选择标准:需要有一个明确的选择标准来决定哪种选择是最好的。
  • 可行性检查:每一步都要确保所作的选择是可行的,即符合问题的约束条件。
  • 贪心选择的顺序:某些情况下,选择的顺序可能会影响最终的结果。

贪心算法的有效性取决于问题本身的特性。对于某些问题,贪心算法可以快速找到最优解;而对于另一些问题,则可能无法得到最优解。因此,在实际应用中需要对问题进行仔细分析以确定贪心算法是否适用。
当然可以。让我们来看一个简单的贪心算法的例子——硬币找零问题。在这个问题中,我们需要用最少数量的硬币来给出找零。假设我们有无限数量的几种面值的硬币(例如1美分、5美分、10美分和25美分)。我们的目标是最小化找零所需的硬币数量。


例题: leetcode.322.零钱兑换

https://leetcode.cn/problems/coin-change/description/
这道题用贪心只能通过51 / 189
因为贪心只寻找局部最优,
要想全部通过,要使用动态规划

def make_change(coins, amount):"""使用贪心算法计算最少硬币数。参数:coins (list of int): 可供使用的硬币面额列表。amount (int): 需要找零的金额。返回:int: 最少需要的硬币数量。"""# 对硬币面额进行降序排序coins.sort(reverse=True)# 初始化结果变量coin_count = 0# 遍历硬币列表for coin in coins:# 计算当前面额硬币的最大数量while amount >= coin:amount -= coincoin_count += 1return coin_count# 定义可用的硬币面额
coins = [25, 10, 5, 1]# 定义需要找零的金额
amount = 63# 调用函数并打印结果
print("最少需要的硬币数量:", make_change(coins, amount))

这段代码首先定义了一个 make_change 函数,该函数接收硬币面额列表和需要找零的金额作为输入。它先将硬币面额按降序排列,然后从最大面额开始尝试使用尽可能多的该面额硬币,直到剩余的金额不足以使用更大的面额为止。最后,函数返回所需的最少硬币数量。

注意,这个贪心算法假设硬币的面额是有规律的(例如美国硬币系统),在这种情况下,它总是能给出最少的硬币数量。但对于其他面额的组合,贪心算法可能不会总是给出最优解。例如,如果硬币面额为 [1, 3, 4] 并且需要找零 6,贪心算法会选择两个面额为 3 的硬币,但实际上最优解是两个面额为 3 和一个面额为 1 的硬币。


例题: leetcode 5.最长回文字符串

https://leetcode.cn/problems/longest-palindromic-substring


class Solution:def longestPalindrome(self, s: str) -> str:# 解题思路1:暴力解法通过70/140,剩余超时,思考超时原因如下:如果s[1:8]不是回文串,就没必要继续看s[1:9]和之后的了,但是暴力没有解决这个问题,还有一些边界也没解决,如果挨个解决太麻烦,所以换个思路。# 解题思路2:中心扩展,从左到右遍历s,以当前位置curr为原点,左右扩展,查看最长回文串,分为奇数回文和偶数回文,这样的好处是,如果s[2:3]不是回文串,就不会继续检查[1:4]或者[2:4】之类的。时间复杂度更低。len_s = len(s)if len_s == 1:return smax_len = 1max_str = s[0]for idx, val in enumerate(s):# 查找偶数回文串,通过率75/142left = idxright = idx + 1while left >= 0 and right < len_s:if s[left] == s[right]:temp_len = right + 1 - leftif temp_len > max_len:max_len = temp_lenmax_str = s[left:right + 1]left -= 1right += 1else:break# 查找奇数回文串 通过率74/142left = idx - 1right = idx + 1while left >= 0 and right < len_s:if s[left] == s[right]:temp_len = right + 1 - leftif temp_len > max_len:max_len = temp_lenmax_str = s[left:right + 1]left -= 1right += 1else:break# 两种合起来通过return max_str

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Csrf复习(pikachu靶场和防御手段)

CSRF漏洞简介 CSRF又称跨站请求伪造&#xff0c;是指攻击者在用户登录的状态下&#xff08;浏览器保存了用户的cookie&#xff09;通过伪造恶意url诱导用户点击&#xff0c;借助用户的cookie网站权限&#xff08;冒充用户身份来进行非法操作&#xff0c;对于服务器来说是合法的…

视觉SLAM第二讲

SLAM分为定位和建图两个问题。 定位问题 定位问题是通过传感器观测数据直接或间接求解位置和姿态。 通常可以分为两类&#xff1a;基于已知地图的定位和基于未知地图的定位。 基于已知地图的定位 利用预先构建的地图&#xff0c;结合传感器数据进行全局定位。SLAM中的全局…

如何利用开源Bug管理系统提高团队效率

国内外主流的10款开源bug管理系统对比&#xff1a;PingCode、Worktile、Trac、WebIssues、MantisBT、Bugzilla 、Fossil、The Bug Genie、TestLink 、OpenProject。 在软件开发的复杂世界中&#xff0c;Bug管理可能是一个令人头疼的问题&#xff0c;尤其是当工具不足以捕捉和解…

这才是做项目的正确打开方式

基于大数据的推荐机制&#xff0c;对于没有接触到信息的人而言&#xff0c;会认为获取行业外的信息会很困难&#xff0c;对于已经接触到信息的人而言&#xff0c;又会出现选择困难症。当系统对你锁定标签后&#xff0c;就会频繁的给你推荐跟标签对应的信息&#xff0c;信息一多…

[PM]面试题-能力问题

你在公司里面主要做什么? 负责产品的全生命周期的管理, 包括产品调研, 需求整理, 产品设计,文档产出, 产品评审, 项目推进, 产品迭代等工作 你是怎么做需求分析的? 首先我们要收集需求, 然后把需求放到需求池里进行管理, 需求管理首先要对需求进行优先级划分, 在根据需求设…

DjangoRF-8-9-modules和interfaces接口

1、接口编写顺序&#xff0c;同6–7一样。

quicgo

quic-go/quic-go 简介: Go语言实现的QUIC协议。&#xff08;QUIC是一个兼顾TCP连接的可靠性&#xff0c;同时大幅降低延迟的通用网络传输层协议&#xff09; | GitHub 中文社区 https://www.github-zh.com/projects/55637575-quic-go quic-go 是 Go 中 QUIC 协议&#xff08;…

Kafka面试三道题

针对Kafka的面试题&#xff0c;从简单到困难&#xff0c;我可以给出以下三道题目&#xff1a; 1. Kafka的基本概念与优势 问题&#xff1a;请简要介绍Kafka是什么&#xff0c;并说明它相比传统消息队列的优势有哪些&#xff1f; 答案&#xff1a; Kafka定义&#xff1a;Apa…

【传知代码】智慧医疗:纹理特征VS卷积特征(论文复现)

在这个无处不在的技术革新的时代&#xff0c;计算机视觉和机器学习成为了医疗领域中不可或缺的力量。在这篇文章中&#xff0c;我们将探讨两种突出的技术&#xff1a;纹理特征和卷积特征。它们如何在医学影像分析中竞争与协作&#xff0c;为医生提供更深入、更精确的诊断信息&a…

iOS基础---常用三方库:Masonry、SDWebImage

系列文章目录 iOS基础—多线程&#xff1a;GCD、NSThread、NSOperation iOS基础—Category vs Extension iOS基础—常用三方库&#xff1a;Masonry、SDWebImage 文章目录 系列文章目录一、Masonry1.Masonry简介2.使用示例3.源码剖析 二、SDWebImage1.SDWebImage简介2.主要功能…

不同WEB下的的ApplicationContext的选择

依赖 ApplicationContext类型选择 默认情况下&#xff0c;spring通过选择的web端的框架来选择使用哪个ApplicationContext子类&#xff0c;默认情况下我们一般使用spring mvc框架&#xff0c;这个时候AC的实现类为 org.springframework.boot.web.servlet.context.AnnotationC…

在 LCD 上显示 png 图片-I.MX6U嵌入式Linux C应用编程学习笔记基于正点原子阿尔法开发板

在 LCD 上显示 png 图片 PNG 简介 无损压缩&#xff1a;PNG 使用 LZ77 派生算法进行无损压缩&#xff0c;确保图像质量不受损&#xff0c;且压缩比高 体积小&#xff1a;通过高压缩比&#xff0c;PNG 文件体积小&#xff0c;适合网络传输 索引彩色模式&#xff1a;PNG-8 格式…

ChatGPT对话:关于训练模型h5格式和SavedModel格式的问题

【编者按】有几天没有更新&#xff0c;一直在学习和调试程序&#xff0c;其中有大量与ChatGPT的对话&#xff0c;遇到的每一个问题都找ChatGPT&#xff0c;再也没有用到百度和google。在ChatGPT的帮助下已完成Python下的花卉识别训练与预测&#xff0c;部署到网站&#xff0c;也…

计划外投料

计划外领料通过A07 R10发料/其他&#xff0c;进行计划外投料。移动类型仍然是261。 在科目分配页签。维护计划外投料的工单号。 在实际业务中&#xff0c;有的企业也会单独复制出一个移动类型。进行区分。 在COOIS中&#xff0c;有张表可以看出物料是计划内投料还是计划外。 …

MySQL查询执行(三):显示随机消息

假设有如下表结构&#xff1a; -- 创建表words CREATE TABLE words (id int(11) NOT NULL AUTO_INCREMENT,word varchar(64) DEFAULT NULL,PRIMARY KEY (id) ) ENGINEInnoDB;--数据生成存储过程 delimiter ;; create procedure idata() begindeclare i int;set i0;while i<…

[工具]GitHub + PicGo 搭建免费博客图床

文章目录 起因GitHub新建GitHub仓库新建token授予picgo权限 PicGOPicGO上传失败原因 起因 还是觉得个人博客记录最好还是不要money&#x1f625;&#xff0c;所以还是想白嫖&#xff0c;找到了GitHub PicGO的方式&#xff0c;记录一下。 GitHub 过程和搭建博客链接类似&…

DDOS攻击学习 - kali初学

文章目录 本地ssh配置nmap(网络连接的工具)nmap -sP IP地址nmap -p 1-65535 -A IP地址主机发现Ping扫描端口扫描时序扫描常用扫描方式指纹识别与探测全端口版本探测防火墙/IDS逃逸报文分段信息收集IP信息收集WHOIS查询数据库渗透测试MySQL列举数据库列举MySQL变量发起请求目录扫…

PostgreSQL的pg-collector工具

PostgreSQL的pg-collector工具 pg-collector 是一个用于 PostgreSQL 数据库的监控和数据收集工具。它主要用于收集 PostgreSQL 实例的性能指标、查询统计和日志信息&#xff0c;以便进行数据库性能分析和故障排查。通过收集这些数据&#xff0c;管理员可以更好地了解数据库的运…

day3 测试基础知识

1. 你认为性能测试的目的是什么&#xff1f;做好性能测试的工作的关键是什么&#xff1f; 性能测试工作的目的是检查系统是否满足在需求说明书中规定的性能&#xff0c;性能测试常常需要和强度测试结合起来&#xff0c;并常常要求同时进行软件和硬件的检测。 性能测试主要的关…

Laravel视图渲染封装

第一种 app/Helpers/ViewHelper.php 创建一个辅助函数&#xff0c;用于动态确定视图路径&#xff1a; <?php if (!function_exists(fetchView)) {function fetchView($data []){$currentAction \Route::currentRouteAction();list($controller, $method) explode(, $c…