精品文档---下载后可任意编辑第五章 并行算法的一般设计谋略习题例题:1、 令 n 是待排序的元素数,p=2d是 d 维超立方中处理器的数目
假定开始随机选定主元x,并将其播送给所有其他处理器,每个处理器按索接收到的 x,对其 n/p 个元素根据≤ x和>x 进行划分,然后按维进行交换
这样在超立方上实现的快排序算法如下:算法 5
6 超立方上快排序算法输入: n 个元素,B = n/p, d = log p输出: 按超立方编号进行全局排序Begin(1)id = processor’s label(2)for i=1 to d do(2
1) x = pivot / * 选主元 * /(2
2) 划分 B 为 B1和 B2满足 B1 ≤B<B2(2
3) if 第 i 位是零 then (i) 沿第 i 维发送 B2给其邻者 (ii) C = 沿第 i 维接收的子序列 (iii) B= B1∪C else (i) 沿第 i 维发送 B1给其邻者 (ii) C = 沿第 i 维接收的子序列 (iii) B= B2∪C endifendfor(3)使用串行快排序算法局部排序 B = n/p 个数End① 试解释上述算法的原理
② 试举一例说明上述算法的逐步执行过程
2、 ① 令 T = babaababaa
P =abab,试用算法 5
4 计算两者的匹配情况
② 试分析 KMP 算法为何不能简单并行化
3、 给定序列〔33,21,13,54,82,33,40,72〕和 8 个处理器,试根据算法 5
2 构造一棵为在 PRAM-CRCW 模型上执行快排序所用的二叉树
4、 计算 duel(p, q)函数的算法如下:算法 5
7 计算串匹配的 duel(p, q) 的算法输入: WIT〔1: n-m+1〕,1≤p<q≤n-m+1,(p - q) < m/2输出: 返回竞争幸存者