适用问题类型:
需要对n个元素(带有一定权重,比如花费,截止日期,持续时间等)进行排序以获得所要求的最优解
例如,你是一个小印刷社的老板,只有一台打印机。你每天都需要面对如下问题:每天早上客户们都会来找你下订单,你需要把这些订单排序依次去完成,而且要尽量让所有顾客满意。如何决定先完成谁的订单,后完成谁的订单呢?
这类问题就可以用到下面的套路了!
套路:
1. 首先考虑只存在两个元素的情况,比如A和B。那么我们可知,只有两种可能的排序情况,要么先A后B,要么先B后A。
2. 对于每种情况,写出其加权的数学表达式。
举例:
还是上面例子中的背景,假设顾客i的订单需要花费ti时间去完成。给出一个时间表(其实就是完成订单的顺序),假设Ci表示i订单完成的时间,比如订单j是你今天第一个要完成的,Cj = tj,如果订