临近期末,把之前做过的题目(有部分是未做过的)重新做一遍,整合到一起,为了省时间,就不贴代码了,只分析思路。
分治算法题目:
1、Search a 2D Matrix II:在一个每行每列都有序的矩阵中搜索某一数字。
2、Kth Largest Element in an Array:找到数组里第k大元素。
可以参考quick select算法,但是我偷懒使用了heap,大端堆的顶部是最大元素,可以根据k,进行几次pop_heap操作得到想要的Kth。
3、Majority Element:找到数组里出现次数 > n/2 的元素。
原先是想另开一个数组tmp,利用tmp[nums[i]]++去计数每个元素出现次数。但是有一个问题——并不知道tmp的大小,因为nums[i]未知,而且可能很大。于是想到了unordered_map,空间O(n),查找时间O(1)的容器,利用nums[i]得到属于它的一个容器(中间经过散列变换,不需要担心tmp的数组越界情况)。
之后遍历unordered_map得到 > n/2 的元素,返回即可。
4、Maximum Subrray:找到数组的和最大的子串。
虽然是分治专题,但是这道题用动态规划解起来很快。数组re[i]表示以nums[i]结尾的子串的最大和。re[i]= max(re[i-1]+ nums[i], nums[i])。
遍历返回最大的re[i]即可。