【贪心法】典型题目和面试题汇总

这篇博客汇总了贪心算法在面试题中的应用,包括Google面试中的任务调度问题和数字问题。针对任务调度问题,提出了每次选择处理时间最短的机器进行任务分配的贪心策略,并利用线段树进行更新。同时,介绍了贪心思想在解决最小生成树问题中的应用,如Kruskal算法。
摘要由CSDN通过智能技术生成

面试题

贪心法是面试中经常考到的问题:

任务调度问题(Google面试题)

  1. 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> > ,
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值