服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言 数据结构堆排序顺序存储(升序)

C语言 数据结构堆排序顺序存储(升序)

2021-05-12 16:09super_yc C/C++

这篇文章主要介绍了C语言 数据结构堆排序顺序存储(升序)的相关资料,需要的朋友可以参考下

堆排序顺序存储(升序)

一: 完全二叉树的概念:前h-1层为满二叉树,最后一层连续缺失右结点!

二:首先堆是一棵全完二叉树:

a:构建一个堆分为两步:⑴创建一棵完全二叉树      ⑵调整为一个堆

(标注:大根堆为升序,小根堆为降序)

   b:算法描述:①创建一棵完全二叉树  

②while(有双亲){
A:调整为大根堆;
B:交换根和叶子结点;
C:砍掉叶子结点;
}

  c:时间复杂度为 O(nlogn)  ,空间复杂度为 O(1), 是不稳定排序!

代码实现:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/*堆排序思想:[完全二叉树的定义:前 h-1 层为满二叉树一最后一层连续缺失右结点(即右子女)],(大根堆升序排序,小根堆降序排列)
  首先堆是一个完全二叉树 ,根据数组下标就可建成了一棵完全二叉树
  其次:while(有双亲){
    A: 调整为一个大根堆         【Adjust()函数实现】
    B: 交换最后一个叶子结点和根结点    【Swap()函数实现】
    C: 砍掉最后一个叶子结点      【即元素个数 n--】
  }
*/
 
#include <iostream>
#define N 100
 
using namespace std; 
 
int b[N]={0};    //存储数据的数组 
int n=0;      //记录数据的总个数【0单元不要,实际元素个数为(n-1)个】
 
void Swap(int *x,int *y){
  int t;
  t=*x;
  *x=*y;
  *y=t;
 
void Adjust(){
  int p;         //记录双亲结点 
  int tag=1;       //记录是否已经调整为大根堆(标志性的变量)
  while(tag){       //判断是否已经调整好为大根堆
    p=(n-1)/2;     //最后一个双亲结点的下标
    tag=0;       //凡是交换后,tag=1,标志着还没有调整为大根堆,否则继续调整 
    while(p>0){     //确保有双亲结点
      if(b[p]<b[2*p]){     //若根结点大于左子女结点,就交换 
        Swap(&b[p],&b[2*p]);
        tag=1;
      }
      if(2*p+1<n && b[p]<b[2*p+1]){ //若存在右子女,并且根结点大于右子女结点,就交换 
        Swap(&b[p],&b[2*p+1]);
        tag=1;     
      }
      p--;        //直到最后一个双亲结点调整完 
    
  
}
 
void HeapSort(){
  while(n>2){         //保证有双亲结点 
    Adjust();        //调整大根堆函数
    Swap(&b[1],&b[n-1]);  //将最后一个叶子结点和根结点交换 
    n--;          //裁剪最后的叶子结点 
  }
}  
    
int main(void){
  int i,m;
  cout<<"请输入数据的总数【0单元不要,实际元素个数为(n-1)个】:"<<endl;
  cin>>n;
  m=n;
  cout<<"请输入各个数据【0单元不要,实际元素个数为(n-1)个】:"<<endl;
  b[0]=0;
  for(i=1;i<n;i++){
    cin>>b[i];
  }
  HeapSort();           //堆排序
  cout<<"大根堆升序排列为:"<<endl;
  for(i=1;i<m;i++){
    cout<<b[i]<<" ";
  
  cout<<endl;
  return 0;
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

原文链接:http://blog.csdn.net/super_yc/article/details/52964080

延伸 · 阅读

精彩推荐
  • C/C++OpenCV实现拼接图像的简单方法

    OpenCV实现拼接图像的简单方法

    这篇文章主要为大家详细介绍了OpenCV实现拼接图像的简单方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    iteye_183805102021-07-29
  • C/C++深入C++拷贝构造函数的总结详解

    深入C++拷贝构造函数的总结详解

    本篇文章是对C++中拷贝构造函数进行了总结与介绍。需要的朋友参考下...

    C++教程网5182020-11-30
  • C/C++c/c++实现获取域名的IP地址

    c/c++实现获取域名的IP地址

    本文给大家汇总介绍了使用c/c++实现获取域名的IP地址的几种方法以及这些方法的核心函数gethostbyname的详细用法,非常的实用,有需要的小伙伴可以参考下...

    C++教程网10262021-03-16
  • C/C++关于C语言中E-R图的详解

    关于C语言中E-R图的详解

    今天小编就为大家分享一篇关于关于C语言中E-R图的详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看...

    Struggler095962021-07-12
  • C/C++c/c++内存分配大小实例讲解

    c/c++内存分配大小实例讲解

    在本篇文章里小编给大家整理了一篇关于c/c++内存分配大小实例讲解内容,有需要的朋友们可以跟着学习参考下。...

    jihite5172022-02-22
  • C/C++C语言实现双人五子棋游戏

    C语言实现双人五子棋游戏

    这篇文章主要为大家详细介绍了C语言实现双人五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    两片空白7312021-11-12
  • C/C++C语言main函数的三种形式实例详解

    C语言main函数的三种形式实例详解

    这篇文章主要介绍了 C语言main函数的三种形式实例详解的相关资料,需要的朋友可以参考下...

    ieearth6912021-05-16
  • C/C++使用C++制作简单的web服务器(续)

    使用C++制作简单的web服务器(续)

    本文承接上文《使用C++制作简单的web服务器》,把web服务器做的功能稍微强大些,主要增加的功能是从文件中读取网页并返回给客户端,而不是把网页代码...

    C++教程网5492021-02-22