贪心的问题合集(Leetcode题解-Python语言)

贪心算法(Greedy Algorithm):是一种在每次决策时采用当前状态下最优或最好的策略,从而希望导致结果是最好或最优的算法。

455. 分发饼干

class Solution:def findContentChildren(self, g: List[int], s: List[int]) -> int:g.sort(reverse=True)s.sort(reverse=True)p1, p2 = 0, 0ans = 0while p2 < len(s) and p1 < len(g):if s[p2] >= g[p1]:ans += 1p1 += 1p2 += 1else:p1 += 1return ans

思路不难,对饼干和孩子进行排序,由大到小,然后从最大的饼干和最大的孩子开始考虑:如果饼干能满足当前孩子,则计数加 1,考虑下一个饼干和孩子;如果不能满足,则考虑下一个孩子。直到孩子或者饼干考虑完为止。

860. 柠檬水找零

class Solution:def lemonadeChange(self, bills: List[int]) -> bool:five = ten = 0for num in bills:if num == 5:five += 1elif num == 10:if five == 0:return Falseelse:five -= 1ten += 1elif num == 20:if ten > 0 and five > 0:five -= 1ten -= 1elif five >= 3:five -= 3else:return Falsereturn True

同样是分类讨论,如果收到 5 块则 5 块加 1,如果收到 10 块则找零 5 块(10块加1,5块减1),如果收到 20 块则优先使用 10 块 + 5 块找零,其次再考虑用 3 张 5 块找零,凡是无法找零都返回 False。

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

class Solution:def largestSumAfterKNegations(self, nums: List[int], k: int) -> int:nums.sort()index = 0while index < len(nums) and k > 0 and nums[index] < 0:nums[index] = -nums[index]index += 1k -= 1if k > 0 and k % 2 != 0:return sum(nums) - 2 * min(nums)else:return sum(nums)

首先对数组排序,从小到大,然后取反先从负数开始(如果有的话),如果没有负数了,还剩余取反次数的话,就只考虑奇数的情况(偶数可以抵消),这时就对最小的正数(也是最小的数,因为没负数了)取反即可。

738. 单调递增的数字

class Solution:def monotoneIncreasingDigits(self, n: int) -> int:a = list(str(n))for i in range(len(a)-1,0,-1):if int(a[i]) < int(a[i-1]):a[i-1] = str(int(a[i-1]) - 1)a[i:] = '9' * (len(a) - i)  return int("".join(a)) 

考虑两个相邻数字的情况,如果左边的比右边大,则为了满足单调递增的条件,必定是左边的数减 1 而右边的数变成 9(因为要单调递增,所以右边所有数都变成 9)。从个位数(右边)向左开始考虑每一对数字的情况,当出现左边数减 1 时,右边的所有数字一定都变成 9。

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

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

相关文章

Magicodes.IE之导入导出筛选器

总体设计Magicodes.IE是一个导入导出通用库&#xff0c;支持Dto导入导出以及动态导出&#xff0c;支持Excel、Word、Pdf、Csv和Html。在本篇教程&#xff0c;笔者将讲述如何使用Magicodes.IE的导入导出筛选器。在开始之前&#xff0c;我们需要先了解Magicodes.IE目前支持的筛选…

字符串经典题目(Leetcode题解-Python语言)

344. 反转字符串 class Solution:def reverseString(self, s: List[str]) -> None:"""Do not return anything, modify s in-place instead."""left 0right len(s) - 1while left < right:s[left], s[right] s[right], s[left]left 1…

谈了千百遍的缓存数据的一致性问题

“灵魂拷问保证缓存和数据库的一致性很简单吗&#xff1f;有哪些方式能保证缓存和数据库的一致性呢&#xff1f;如果发生了缓存和数据库数据不一致的情况怎么办呢&#xff1f;在上篇文章我们介绍了缓存的定义分类以及优缺点等&#xff0c;如果还没看的同学可以移步这里听说你会…

BS作业 基于springboot + Thymeleaf +mybatis 实现的书城管理系统

一:项目背景 项目描述 一个基本功能较为完整的后台管理项目。项目主要功能有&#xff1a;登录验证&#xff0c;登录功能还加入了随机验证码的验证&#xff1b; 用户注册&#xff0c;注册中密码基于srping 安全框架提供的加密(自动加盐)的密码储存方式&#xff0c;对注册重名进…

字符串匹配经典题目——KMP算法(Leetcode题解-Python语言)

28. 实现 strStr() strStr(haystack: str, needle: str) 的作用就是在 haystack 字符串&#xff08;长度为 n&#xff09;中找出 needle 字符串&#xff08;长度为 m&#xff09;出现的第一个位置&#xff08;下标从 0 开始&#xff09;。如果不存在&#xff0c;则返回 -1 &am…

Istio Pilot 源码分析(二)

张海东&#xff0c; ‍多点生活&#xff08;成都&#xff09;云原生开发工程师。本篇主要介绍 Pilot 源码中的 ServiceEntryStore 及其推送 xDS 的流程。本文为 Istio Pilot 源码分析系列的第二篇文章。Istio Pilot 源码分析&#xff08;一&#xff09;了解了 Pilot 源码的基本…

Pytorch中的 torch.Tensor() 和 torch.tensor() 的区别

直接在搜索引擎里进行搜索&#xff0c;可以看到官方文档中两者对应的页面&#xff1a; 分别点击进去&#xff0c;第一个链接解释了什么是 torch.Tensor&#xff1a; torch.Tensor 是一个包含单一数据类型元素的多维矩阵&#xff08;数组&#xff09;。 正因为 torch.Tensor 只包…

leetcote34. 在排序数组中查找元素的第一个和最后一个位置

一:题目 二&#xff1a;上码&#xff08;暴力二分&#xff09; // class Solution { // public: // /** // 思路:1.首先这是一个升序的 那么相同的一定是会相连的// */// vector<int> searchRange(vector<int>& nums, int target) {// …

Git 图形化操作之合并提交记录

Git 图形化操作之合并提交记录独立观察员 2020 年 9 月 24 日目录1、显示日志2、合并提交记录3、推送合并的提交前言&#xff1a;当我们使用 Git 时&#xff0c;有时会遇到刚提交推送完一次修改&#xff0c;发现漏了该某处&#xff0c;只好又提交推送一次&#xff0c;这样在提交…

Pytorch中的 torch.as_tensor() 和 torch.from_numpy() 的区别

之前我写过一篇文章&#xff0c;比较了 torch.Tensor() 和 torch.tensor() 的区别&#xff0c;而这两者都是深拷贝的方法&#xff0c;返回张量的同时&#xff0c;会在内存中创建一个额外的数据副本&#xff0c;与原数据不共享内存&#xff0c;所以不受原数据改变的影响。 这里…

chrome禁止三方cookie,网站登录不了怎么办

背景新版chrome(80)浏览器默认屏蔽所有三方cookie已经不是什么新闻了&#xff0c;具体原因这里不去深究&#xff0c;有大量相关文章介绍&#xff0c;由于目前许多网站都依赖三方cookie&#xff0c;因此该特性的推出还是造成了一些的影响&#xff0c;比如收集用户信息的广告商&a…

leetcode69. x 的平方根

一:题目 二:上码 class Solution { public:/**思路:1.因为我们的 ans的平方 < x 那么我们就可以用二分法来做 不断缩小左右范围来确定 ans**/int mySqrt(int x) {int left 0; int right x;int ans 0;while (left < right) {long mid (right-left)/2 left;if (mid*…

两数、三数、四数之和相关题目(Leetcode题解-Python语言)

作为 Leetcode 的第一题&#xff0c;两数之和自然是知名度最高的&#xff0c;从两数之和出发也有不少的衍生题目&#xff0c;下面就让我们好好地解决它们。 1. 两数之和 class Solution:def twoSum(self, nums: List[int], target: int) -> List[int]:record dict()for i…

初识ABP vNext(11):聚合根、仓储、领域服务、应用服务、Blob储存

点击上方蓝字"小黑在哪里"关注我吧聚合根仓储领域服务BLOB储存应用服务单元测试模块引用前言在前两节中介绍了ABP模块开发的基本步骤&#xff0c;试着实现了一个简单的文件管理模块&#xff1b;功能很简单&#xff0c;就是基于本地文件系统来完成文件的读写操作&…

leetcode367. 有效的完全平方数

一:题目 二:上码 class Solution { public:/**完全平方数:若一个数能表示成某个整数的平方的形式&#xff0c;则称这个数为完全平方数思路:1.我们将num先折半,因为它是某个整数的平方&#xff0c;而这个数的范围肯定不会超过num的一半2.那么这就相当于在[left,num/2]中查找某个…

二叉树最近公共祖先相关题目(Leetcode题解-Python语言)

236. 二叉树的最近公共祖先 class Solution:def lowestCommonAncestor(self, root: TreeNode, p: TreeNode, q: TreeNode) -> TreeNode:def dfs(root: TreeNode, p: TreeNode, q: TreeNode):# 如果当前节点为空&#xff0c;则说明 p、q 不在 node 的子树中&#xff0c;不可…

跟我一起学.NetCore之文件系统应用及核心浅析

前言在开发过程中&#xff0c;肯定避免不了读取文件操作&#xff0c;比如读取配置文件、上传和下载文件、Web中html、js、css、图片等静态资源的访问&#xff1b;在配置文件读取章节中有说到&#xff0c;针对不同配置源数据读取由对应的IConfigurationProvider进行读取&#xf…

深度学习入门笔记(1)——导论部分

此笔记来源于 Sebastian Raschka 的 Introduction to Deep Learning 系列课程。 首先介绍的是传统的编程范式&#xff0c;假设我们想实现垃圾邮件识别的功能&#xff0c;传统的方法就是由程序员来找出垃圾邮件的规则并对其进行编程&#xff0c;得到一个垃圾邮件识别的程序。 机…

新版 C# 高效率编程指南

前言C# 从 7 版本开始一直到如今的 9 版本&#xff0c;加入了非常多的特性&#xff0c;其中不乏改善性能、增加程序健壮性和代码简洁性、可读性的改进&#xff0c;这里我整理一些使用新版 C# 的时候个人推荐的写法&#xff0c;可能不适用于所有的人&#xff0c;但是还是希望对你…