关于贪心算法章节的【有两个维度问题】的自我总结
一、如果一道题目需要同时满足两个维度,那么在实际做题的时候不要两个维度一起考虑。
二、关键:先考虑一个维度,再根据另一个维度做调整。
(一眼看上去不知道先考虑哪个维度,就先抓其中的一个维度先考虑试一下,模拟一下过程)
三、两个例题
例题1:分发糖果。题目要求要同时满足比左边的多,又要比右边的多。
那么就先处理比左边多的情况,再处理比右边多的情况。代码如下图右侧所示。
例题2:根据身高重建队列。既要考虑满足身高顺序要求,又要满足另一个条件
但是一眼看上去不知道哪一个先考虑比较好,就先考虑其中一个条件试一下,模拟一下过程。
(比如:如果先考虑第二个参数,按第二个参数从小到大排序,排完以后再按身高排序。此时两个条件都会变来变去,并没有因为先考虑了第二个参数而定了其中一个顺序。说明不合适,所以优先按身高从大到小排序,再用第二个参数做调整。)
