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

《算法导论(第三版)》第六章,堆排序的应用之最大优先队列

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
《算法导论(第三版)》第六章,堆排序的应用之最大优先队列
: C" |9 U2 E! ?( f; v1 b. d/ I6 B" i
主函数:
0 v  G2 t: Z9 ]" w" h
  • %测试任意功能前,需将其它功能注释了
  • clear;clc
  • A=[16 14 10 8 7 9 3 2 4 1]%测试队列
  • %[A MAX]=HEAP_EXTRACT_MAX(A)  %提取最大值
  • %HEAP_INCREASE_KEY(A,9,3);%3<4,当前测试会报错
  • %HEAP_INCREASE_KEY(A,9,15)%15>4,8取代4,并且15会到第二位置
  • A=MAX_HEAP_INSERT(A,17)%队列长度+1,17将会在第一位,
    * J( U9 ^$ j+ f/ Z3 [7 o* k4 o' M2 }
8 V, n$ v/ c- n9 c- ?* @/ L

4 x& A2 t- ?/ {6 WHEAP_INCREASE_KEY
' J/ k% x9 ]+ Q" T1 O
  • function [A] = HEAP_INCREASE_KEY(A,i,key)
  • if key<A(i)%新更新的值比原值小,则直接报错
  •     error('new key is smaller than current key');
  • end
  • A(i)=key;%更新值
  • while i>1 & A(floor(i/2))<A(i)%父值比子值小,则一直更新
  •     temp=A(i);
  •     A(i)=A(floor(i/2));
  •     A(floor(i/2))=temp;
  •     i=floor(i/2);
  • end
  • end1 g0 g4 o% w) M
; \' b1 r6 c. m

- Z7 G* s! @! c$ R) X. sHEAP_EXTRACT_MAX; |0 {3 i3 H) J; Y/ p" r
  • function [A,MAX] = HEAP_EXTRACT_MAX(A)
  • if length(A)<1%A为空,则报错
  •     error('heap undeRFlow!')
  • end
  • MAX=A(1);%A(1)就是优先队列的最大值
  • A(1)=A(end);%末尾的提到最前
  • A(end)=[];%去掉末尾
  • A=MAX_HEAPIFY(A,1);%重新进行一次排列
  • end
    ; @' j* `5 z4 L) C; Q

3 h7 W1 I1 f  v3 |; }/ R# y8 n9 [

% t& ?8 u0 F  w6 ?1 ]% WMAX_HEAP_INSERT
' H; Z/ F: l% e2 x6 J4 n( B' e
  • function [A] = MAX_HEAP_INSERT(A,key)%加入新值
  • A(end+1)=-inf;%长度+1
  • A=HEAP_INCREASE_KEY(A,length(A),key);
  • end& x8 T/ ~, z3 o: e4 K
2 S! ~4 Z0 E% y* w/ g  T# T5 Q
) L5 ]7 h' }! O% i7 b. _3 ]
MAX_HEAPIFY. j9 y! Y- w, w$ H5 t8 i- F5 a
  • function [A] = MAX_HEAPIFY(A,i)%前面已经写过了,直接调用
  • l=2*i;%左节点序号
  • r=2*i+1;%右节点序号
  • %比较该节点与左右子节点的大小
  • if l<=length(A) & A(l)>A(i)
  •     largest=l;
  • else
  •     largest=i;
  • end
  • if r<=length(A) & A(r)>A(largest)
  •     largest=r;
  • end
  • %如果最大子节点变换,则交换,继续递归。
  • if largest~=i
  •     temp=A(i);
  •     A(i)=A(largest);
  •     A(largest)=temp;
  •     A=MAX_HEAPIFY(A,largest);
  • end
  • end% o+ [2 b. D! |9 z- M- o% q

, F3 a1 D) c) w  X0 \( I5 o
7 M: o# P, h& c4 z0 ]0 O0 R
4 S; x( y( q2 x) n0 m: U7 o5 |4 I

该用户从未签到

2#
发表于 2020-3-10 17:48 | 只看该作者
堆排序的应用之最大优先队列。

该用户从未签到

3#
发表于 2020-3-11 16:59 | 只看该作者
堆排序的应用之最大优先队列) 。

该用户从未签到

4#
发表于 2020-3-12 18:15 | 只看该作者

$ W8 v, a7 G) u3 p$ S堆排序的应用之最大优先队列。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-23 23:41 , Processed in 0.140625 second(s), 23 queries , Gzip On.

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

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

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