| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1470 人关注过本帖
标题:没结果怎么改最小堆
只看楼主 加入收藏
http8852490
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-11-1
结帖率:50%
收藏
 问题点数:0 回复次数:0 
没结果怎么改最小堆
#include<iostream.h>
void swap(int &a,int &b){int c;c=a;a=b;b=a;}
class minheap{
private:
    int a[100];
    int csize,msize;
public:
    minheap(int b[],int m);
    void siftdown(int parent);
    void siftup(int j);
    void buildheap();
    void output();};
minheap::minheap(int b[],int m)
{int i;
for(i=0;i<m;i++)  a[i]=b[i];
csize=m;}
void minheap::siftdown(int parent)
{int i=parent;int j;
 j=2*i+1;                         //j为i的左孩子
while(j<csize){
    if((j<csize-1) && (a[j]>a[j+1]))   
        j++;
    if(a[i]>a[j]){
        swap(a[i],a[j]);
        i=j;
        i=2*j+1;}
    else break;}}
void minheap::siftup(int j)
{int p=(j-1)/2;
while((j>0) && (a[p]>a[j])){
    swap(a[j],a[p]);
    j=p;}}
void minheap::buildheap(){
for(int i=csize/2-1;i>=0;i++)   
siftdown(i);}
void minheap::output(){
for(int i=0;i<csize;i++)
cout<<a[i]<<' ';
cout<<endl;}
void main()
{int a[10]={14,25,20,17,24,22,26,18,15,12};
minheap A(a,10);
A.buildheap(); A.output();}




      
搜索更多相关主题的帖子: private void include public parent 
2012-11-24 21:27
快速回复:没结果怎么改最小堆
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.022879 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved