面试题
贪心法是面试中经常考到的问题:
任务调度问题(Google面试题)
- N个job,所有job都一样,M台机器,每个机器i处理job的时间是ci,求最短时间把job都弄完
相当于M条队列,放不同宽度的砖头,最后砖头数量一定,问M条队列的宽度最小值。
- 贪心: 每次选择ti+ci最小的队列放砖头。ti为队列i当前宽度。ti+ci为放入砖头后的队列i宽度。
- 另外放砖头后需要更新队列i的(ti+ci),更新方法: 线段树(叶节点i保存队列i当前的ti+ci)中更新区间[i, i](从ti+ci变成(ti+ci)+ci )
- 下一次找出根节点,即ti‘+ci’最小的叶节点编号i‘,对应宽度最小的砖头队列继续放砖头。
- 统计M条队列的宽度: max( 叶节点的值-ci)。
另外一种办法:使用优先队列(小顶堆)Priority<pair<int, int> > ,