小根堆的建立和插入(数据结构)
建立一个小根堆,并插入参考样例如下:
·
建立一个小根堆,并插入
#include<bits/stdc++.h>
using namespace std;
int Size=10000;
void Siftup(int *arr,int start)
{
int j = start;
int i = (j - 1)/2; //i是j的双亲
int temp = arr[j];
while(j > 0)
{
if(arr[i] >= temp) break;
else
{
//双亲大向下落,继续向上检测
arr[j] = arr[i];
j = i;
i = (i - 1)/2;
}
}
arr[j] = temp;
}
bool insert(int *arr,int &len,int x)
{
if(len==Size) //堆已满
return false;
arr[len]=x;
Siftup(arr,len); //向上调整
len++;
return true;
}
void Sift(int r[],int k,int m)
{
int i=k,j=2*i;
i--;
j--;
while(j<=m)
{
if(j<m&&r[j]<r[j+1])
j++;
if(r[i]>r[j])
break;
else
{
int temp=r[i];
r[i]=r[j];
r[j]=temp;
i=j;
j=2*i;
}
}
}
int main()
{
int arr[]={49,38,27,49,76,13,65,97};
int n=sizeof(arr)/sizeof(arr[0]);
for(int i=n/2;i>=1;i--)
Sift(arr,i,n);
cout<<"处理为堆后结果如下"<<endl;
for(int i=0;i<n;i++)
cout<<arr[i]<<" ";
cout<<endl;
int insernum;
cin>>insernum;
insert(arr,n,insernum);
cout<<"插入后结果如下"<<endl;
for(int i=0;i<n;i++)
cout<<arr[i]<<" ";
}
参考样例如下:

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐
所有评论(0)