贪心算法(两个实例)

本文探讨了调度问题中使用贪心算法对任务进行最短时间排序以求总完成时间最小化,以及投资问题中如何通过单位重量价值最大化策略来分配资金以获取最大效益。同时涉及算法设计、问题建模及贪心策略的证明与局限性。
摘要由CSDN通过智能技术生成

例一:调度问题

问题:由n项任务,每项任务的加工时间已知,从零时刻开始陆续加入一台机器上去加工,每个任务完成的时间是从0时刻到任务加工截至的时间。

求总完成时间(所有任务完成时间最短计划方案)

解:任务集合{1,2,3,4,5}

加工时间:t1=3,t2=8,t3=5,t4=10,t5=15

排序:t1<t3<t2<t4<t5

贪心算法的解:

3581015

                      0                 3                 8                  16                      26                      41

t总=3+(3+5)+(3+5+8)+(3+5+8+10)+(3+5+8+10+15)

     =3*5+5*4+8*3+10*2+15

     =94

问题建模:

输入任务集:

{1,2,3,4,......n}

第j项任务加工时间:tj∈Z+,j=1,2,3,4.....n

输出调度I,S的排列,i1,i2,i3,.....in,

t(I)= n/k=1∑(n-k+1)

解使得I*t(I*)值是最小:

贪心算法策略:加工时间按最短先做。

算法:加工时间按从小到大排序,依次加工。

证明:加入调度f的第i,j项任务相邻且有逆序。即ti>tj,交换任务i和j得到调度g

ftitg
9tgti

带入公式:

t(I)= n/k=1∑(n-k+1)

的:tg-ti<0

直觉不一定正确:

标号1234
重量3452
价值7992

思路:贪心算法:单位重量价值大的优先,总重不超过6

7/3>9/4>9/5>1

1,2,3,4

贪心算法的解:{1,4}重量5,价值9

更好的解:{2,4}重量6,价值11

算法设计:

  1. 问题建模
  2. 选择什么算法?如何描述这个算法?
  3. 这个算法是否所有的实列都得到最优解?如何证明?
  4. 如果不是能否证明?


例二投资问题

问题:m元钱,投资n个项目,效益函数fi(x),表示第i个投资项目x元的效益,i=1,2,3,......n,求如何分配每个项目的钱使得收入效益最大?

实例:5万元,投给四个项目:

xf1(x)f2(x)f3(x)f4(x)
00000
1110220
21251021
313103022
414153223

515204024

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值