复习一:分治算法

临近期末,把之前做过的题目(有部分是未做过的)重新做一遍,整合到一起,为了省时间,就不贴代码了,只分析思路。


分治算法题目:


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]即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值