Python 练习 LeetCode 贪心算法
整理 LeetCode 贪心算法题目的 Python 解答。保持更新
刷题顺序参考:https://www.jianshu.com/p/460edbe3dc36
题目分类 题目编号
数组与贪心算法 605、121、122、561、455、575、135、409、621、179、56、57、228、452、435、646、406、48、169、215、75、324、517、649、678、420
子数组与贪心算法 53、134、581、152
子序列与贪心算法 334、376、659
数字与贪心 343
单调栈法 496、503、456、316、402、321、84、85
1. 数组与贪心算法
455
贪心算法中,涉及两个有序数组的问题可以用同向双指针来解
135
两次遍历的思路好想一点,但还可以进一步优化空间复杂度
贪心算法的特点是不需要依据全局所有的信息做出当前的决策,往往只需要最值、相邻信息等数据即可
621 题解 1
621 题解 2
官方题解中提供了 2 个思路。第 1 个思路好想一点,第 2 个思路把问题抽象到了更简单的层次,如果直接想到第 2 个思路的话代码会很简单。题解 2 和官方题解的第 2 个思路一样,代码实现效率更高,而官方题解的第 2 个思路的代码更简洁
179
字典序下的贪心解法。注意 Python 语法:
strs = sorted(strs, key=functools.cmp_to_key(cmp), reverse=True)