找回密码
 注册
关于网站域名变更的通知
查看: 399|回复: 2
打印 上一主题 下一主题

《算法导论(第三版)》第十六章,贪心算法

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-3-9 11:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
《算法导论(第三版)》第十六章,贪心算法
$ \$ A  w  i; D$ c' z& Y16.1 活动选择问题- G' v  v# f3 f$ {
PS:为了代码方便,在相同思想下,将原始题目序列的首位加上0+ k2 B: v+ s2 z6 q: ]& `
  • %该段代码的必备条件:序列以活动结束时间递增顺序排列
  • %《算法导论》 第十六章 贪心算法 16.1活动选择问题
  • clear;clc
  • s=[0 1 3 0 5 3 5 6 8 8 2 12];%活动开始时间
  • f=[0 4 5 6 7 9 9 10 11 12 14 16];%活动结束时间
  • a=RECURSIVE_ACTIVITY_SELECTOR(s,f,1,length(s))%活动选择! {) t: J0 x2 Q

; \7 [5 Q7 o- v9 L* t9 d
$ L7 ?+ |+ c* J
  b& p7 e6 m8 S+ a+ Y  D
3 o# W3 |0 l+ n- O! k

, P; P# x- H# j! J- d递归活动选择器
1 C2 ?4 T7 ^* j3 G3 \2 \: J) s1 d. Z
  • function [a] = RECURSIVE_ACTIVITY_SELECTOR(s,f,k,n)
  • %递归活动选择器
  • %a 返回的序列结果
  • m=k+1;
  • while m<=n & s(m)<f(k)%检查是否兼容
  •     m=m+1;%若不兼容,进行下一位判断
  • end
  • if m<=n%整个序列
  •     a=[m RECURSIVE_ACTIVITY_SELECTOR(s,f,m,n)];%[当前最优值+在该条件下的后续最优值]
  • else
  •     a=[];%所有搜索完毕,返回空值
  • end
  • end* G4 U/ r, e8 c/ i1 j

% M# Q* m, W( o" ?
7 b  e1 k% f$ }9 X: b8 U9 D
6 }: w1 N& m$ J& v# P; o1 W
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-8-5 02:45 , Processed in 0.109375 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表