- 1、本文档共38页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
chapter6ppt整理
heap sort java program public static void heapsort( Comparable [ ] a ) { for( int i = a.length / 2; i = 0; i-- ) percDown( a, i, a.length ); for( int i = a.length – 1; i 0; i-- ) { swapReferences( a, 0, i ); percDown( a, 0, i); } } heap sort private static void percDown( Comparable [ ] a, int i, int n ) { int child; Comparable tmp; for( tmp = a[ i ]; leftChild( i ) n; i = child ) { child = leftChild( i ); if( child != n – 1 a[child ].compareTo( a[ child + 1 ]) 0 ) child++; if( pareTo( a[ child ] ) 0 ) a[ i ] = a[ child ]; else break; } a[ i ] = tmp; } private static int leftChild( int i ) { return 2 * i + 1; } 6.4.Applications of Priority Queues 2. The Selection Problem 3. Event Simulation 6.4.Applications of Priority Queues 2. The Selection Problem 在N个元素中找出第K个最大元素。 第一章给出了两个算法: 1A算法:读入N个元素, 并将其排序,返回适当的元素。 运行时间:O( N2 ) 1B算法: 1) 将K个元素读入数组, 并对其排序(按递减次序)。 最小者在第K个位置上。 2) 一个一个地处理其余元素: 每读入一个元素与数组中第K个元素(在K个元素中为最小)比较, 如果 , 则删除第K个元素,再将该元素放在合适的位置上。 如果 , 则舍弃。 最后在数组K位置上的就是第K个最大元素。 例如:3, 5, 8, 9, 1, 10 找第3个最大元素。 6.4.Applications of Priority Queues 运行时间(1B 算法): O( K2 + ( N - K)*K ) = O( N*K ) 当 K = ? N / 2 ? , O( N2 ) 试验: 在 N = 100 万个元素中, 找第 500,000 个最大元素。 以上两个算法在合理时间内均不能结束, 都要处理若干天才算完. 用堆来实现: 6A算法:假设求第K个最小元素 1)将N个元素建堆(最小) O( N ) 2) 执行K次delete O( K*logN ) O( N + K * log N ) 如果 K = ?N / 2? , ?( N * log N ) 如果 K = N , O( N * log N ) 堆排序 6.4.Applications of Priority Queues 6B算法:假设求第K个最大元素 1)读入前K个元素, 建立最
您可能关注的文档
- C 程序设计教程3.ppt
- C 的二节.ppt
- BMW历史官方版.ppt
- BP神经网络详解与实例.ppt
- C 控制结构.ppt
- C 数据类型与运算符.ppt
- B第二章夏 商 西周与春秋时期的教育.ppt
- c 4 函数与预处理.ppt
- C 程序设计(谭浩强完整版).ppt
- C6000指令集.ppt
- 蒸压加气混凝土砌块单位产品综合能耗限额及计算方法.pdf
- crank-it-ticket-redemption-game-service-用户维护说明书手册-baytek.pdf
- FMS_v1.3_用户安装调试说明书.pdf
- allied-tank-attack-motion-simulator-video-arcade-game-service-用户维护说明书手册-injoy-motion.pdf
- batman-ticket-redemption-arcade-game-用户维护说明书手册-coastal-amusements.pdf
- 亿联VCS用户指南.pdf
- deal-or-no-deal-video-redemption-games-complete-family-service-用户维护说明书手册s-ice.pdf
- Disney-Crossy-Road-Arcade-Game-Service-用户维护说明书手册-Adrenaline-Amusements.pdf
- digital-bubbler-jukebox-model-1015-用户维护说明书手册-chicago-gaming.pdf
- ETHOS_EDGE_用户快速操作说明书手册.pdf
文档评论(0)