leetcode1_455.分发饼干

leetcode学习算法第一天

按照LeetCode 101 - A Grinding Guide.pdf进行学习
该书籍作者的Github链接为
该书籍在线学习网站

题目描述

分发饼干

假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。

对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干 j,都有一个尺寸 s[j] 。如果 s[j] >= g[i],我们可以将这个饼干 j 分配给孩子 i ,这个孩子会得到满足。你的目标是满足尽可能多的孩子,并输出这个最大数值。

示例 :

输入: g = [1,2,3], s = [1,1]

输出: 1

解释:

你有三个孩子和两块小饼干,3 个孩子的胃口值分别是:1,2,3。

虽然你有两块小饼干,由于他们的尺寸都是 1,你只能让胃口值是 1 的孩子满足。

所以你应该输出 1。

代码

python 复制代码
class Solution:
    def findContentChildren(self, g: List[int], s: List[int]) -> int:
        g.sort()
        s.sort()
        n = 0 
        for i in s:
            if n < len(g) and i >= g[n]:
                n = n+1
        return n   

调用测试

python 复制代码
g = [1, 2, 3]     # 孩子们的胃口值
s = [1, 2]        # 饼干的尺寸
# 创建 Solution 类的实例
solution = Solution()
# 调用方法
result = solution.findContentChildren(g, s)
# 输出结果
print("最多能满足", result, "个孩子")

刚开始时if处的判断为: if i >= g[n] and n < len(g):

在leetcode运行测试报错,报的结果为超出了列表g的范围,因为给的测试不一定g比s长,后面把n的长度判断提在前面,解决报错,可以正确运行。

这是我照着这本书做的第一个题,希望能坚持下去。在这写博客记录学习过程,感谢大家观看,也感谢这本书的作者!

编码一看就会,一做就废,还是需要上手多加练习!

相关推荐
fie88898 小时前
NSCT(非下采样轮廓波变换)的分解和重建程序
算法
晨晖28 小时前
单链表逆转,c语言
c语言·数据结构·算法
YoungHong19929 小时前
面试经典150题[072]:从前序与中序遍历序列构造二叉树(LeetCode 105)
leetcode·面试·职场和发展
im_AMBER10 小时前
Leetcode 78 识别数组中的最大异常值 | 镜像对之间最小绝对距离
笔记·学习·算法·leetcode
鼾声鼾语10 小时前
matlab的ros2发布的消息,局域网内其他设备收不到情况吗?但是matlab可以订阅其他局域网的ros2发布的消息(问题总结)
开发语言·人工智能·深度学习·算法·matlab·isaaclab
LYFlied11 小时前
【每日算法】LeetCode 25. K 个一组翻转链表
算法·leetcode·链表
Swizard11 小时前
别再迷信“准确率”了!一文读懂 AI 图像分割的黄金标尺 —— Dice 系数
python·算法·训练
s090713611 小时前
紧凑型3D成像声纳实现路径
算法·3d·声呐·前视多波束
可爱的小小小狼11 小时前
算法:二叉树遍历
算法
d111111111d12 小时前
在STM32函数指针是什么,怎么使用还有典型应用场景。
笔记·stm32·单片机·嵌入式硬件·学习·算法