#include<stdio.h>
#include<stdlib.h>
#define CAPACITY 20 /*堆有两个性质:
* 1.结构性:堆必须是一颗完全二叉树
* 2.堆序性:堆的父节点要么都大于子节点,要么小于子节点,前者叫大顶堆,后者叫小顶堆;
* 由此,堆可以用一个数组来表示,并有如下性质:
* 1.对于任意i位置的元素,他的左子节点在2i位置,右子节点在2i+1位置;
* 2.他的父节点(假如有)在i/2位置*/ /*创建一个小顶堆,size代表的是实际元素的个数*/
typedef struct MinHeap {
int size;
int data[CAPACITY];
} heap; void init( heap *h );
void insert(heap *h,int x);
void travel(heap *h); /*数组0位置要空着*/
void init( heap *h ) {
h->size=;
} void insert(heap *h,int x) {
if(h->size == CAPACITY) {
printf("heap is full!");
return;
}
int i;
h->size++;
for(i=h->size; i>=; i/=) {
if(x < h->data[i/]) {
h->data[i]=h->data[i/];
} else {
break;
}
}
h->data[i]=x;
}
/*删除最小元素,在小顶堆即意味着删除根节点
* 1.首先将根元素保存,等待最后return;
* 2.将最后一个元素赋值给根元素,并将这个值赋给缓冲区,这样保证了堆的结构性;
* 3.从根节点开始遍历,比较父节点和两个子节点的大小,如果缓冲区值大于较小的子节点,则将小节点的值赋给父节点
* 4.直到缓冲区值小于游标的两个子节点,此时将缓冲区值赋给游标所在位置*/
int deleteMin(heap *h) {
int child;
int result=h->data[];
h->data[]=h->data[h->size];
h->size--;
int i=;
int temp=h->data[];
for(i=; *i <= h->size; i=child) {
child=*i;
if(child !=h->size && h->data[child] > h->data[child+] ) {/*如果左子节点非最后元素且>右子节点,则右子节点最小*/
child++;
}
if(temp > h->data[child]) {/*如果temp大于当前元素的最小子节点,则将最小子节点赋值给父节点,否则跳出*/
h->data[i]=h->data[child];
} else {
break;
}
}
h->data[i]=temp;/*将缓冲区值赋给当前游标*/
return result;
} /*遍历堆数组:越过空白位置0,从1开始*/
void travel(heap *h) {
int i;
for(i=; i<=h->size; i++) {
printf("%d ",h->data[i]);
}
printf("\n");
} /*堆排序*/
void heap_sort(int a[],int n) {
int i;
heap *h=(heap*)malloc(sizeof(heap));/*给堆指针分配空间*/
init(h);/*初始化堆*/
for(i=; i<n; i++) {/*将数组的元素依次插入堆*/
insert(h,a[i]);
}
for(i=; i<n; i++) {
a[i]=deleteMin(h);
}
}
/*遍历数组*/
void travel_array(int a[],int n) {
int i;
for(i=; i<n; i++) {
printf("%d ",a[i]);
}
printf("\n");
} main() {
int a[]= {,,,,,,,,,,,,,,,};
int n=sizeof(a)/sizeof(int);
travel_array(a,n);
heap_sort(a,n);
travel_array(a,n);
}

C语言实现常用数据结构——堆的更多相关文章

  1. C语言实现常用数据结构——链表

    #include<stdio.h> #include<stdlib.h> typedef struct Node { int data; struct Node *next; ...

  2. C语言实现常用数据结构——图

    #include<stdio.h> #include<stdlib.h> #define SIZE 20 #define LENGTH(a) (sizeof(a)/sizeof ...

  3. C语言实现常用数据结构——二叉树

    #include<stdio.h> #include<stdlib.h> #define SIZE 10 typedef struct Tree { int data; str ...

  4. C语言实现常用数据结构——队列

    #include<stdio.h> #include<stdlib.h> #define MAX_SIZE 10 /* 用一个动态数组来实现队列 */ typedef stru ...

  5. C语言实现常用数据结构——栈

    #include<stdio.h> #include<stdlib.h> //用链表实现栈 typedef struct Node { int data; struct Nod ...

  6. C++常用数据结构的实现

    常用数据结构与算法的实现.整理与总结 我将我所有数据结构的实现放在了github中:Data-Structures-Implemented-By-Me 常用数据结构与算法的实现.整理与总结 KMP字符 ...

  7. 1. C语言中的数据结构.md

    C语言内建数据结构类型 整型 整型数据是最基本的数据类型,不过从整形出发衍生出好几种integer-like数据结构,譬如字符型,短整型,整型,长整型.他们都是最基本的方式来组织的数据结构,一般是几位 ...

  8. 常用数据结构及复杂度 array、LinkedList、List、Stack、Queue、Dictionary、SortedDictionary、HashSet、SortedSet

    原文地址:http://www.cnblogs.com/gaochundong/p/data_structures_and_asymptotic_analysis.html  常用数据结构的时间复杂度 ...

  9. php常用数据结构

    # 常用数据结构--------------------------------------------------------------------------------## 树(Tree)- ...

随机推荐

  1. C++技术问题总结-第0篇 类型转换

    从今天開始,对C++经常使用技术做个总结. 參考书籍:<C++Primer>.<C++对象模型>.<设计模式>.<Windows核心编程>.<ST ...

  2. Struts2——(2)配置文件、通配符

    一.Struts配置文件 (1)struts-default.xml(框架自带) 定义了一些框架自带的Result组件,拦截器组件. <package name="struts-def ...

  3. Android 如何检索Android设备的唯一ID

    关于本文档 Android的开发者在一些特定情况下都需要知道手机中的唯一设备ID.例如,跟踪应用程序的安装,生成用于复制保护的DRM时需要使用设备的唯一ID.在本文档结尾处提供了作为参考的示例代码片段 ...

  4. Android开发小知识

    修改Android app图标(Android Studio) 1.  res\drawable 放置icon.png(此图片是你需要修改的图标); 2.  修改AndroidManifest.xml ...

  5. 使用WPF创建画图箭头

    原文:使用WPF创建画图箭头 今天要给leader line画个箭头,所以就google一下,找到下面的文章,写的不错,可以实现我的需求,所以就摘录下来. 我把源代码中的arraw.cs加入到我的工程 ...

  6. 利用WPF的ListView进行大数据量异步加载

    原文:利用WPF的ListView进行大数据量异步加载 由于之前利用Winform的ListView进行大数据量加载的时候,诟病良多,所以今天试着用WPF的ListView来做了一下,结果没有让我失望 ...

  7. CCNP路由实验之七 动态路由之BGP

     CCNP路由实验之七 动态路由之BGP 动态路由协议能够自己主动的发现远程网络,仅仅要网络拓扑结构发生了变化,路由器就会相互交换路由信息,不仅能够自己主动获知新添加的网络,还能够在当前网络连接失 ...

  8. 执行xcopy命令后出现Invalid num of parameters错误的解决办法

    作者:朱金灿 来源:http://blog.csdn.net/clever101 在执行一条批处理命令: xcopy /s /i /y C:\ppt D:\Program doc 开始很纳闷,上网一查 ...

  9. ios-利用键盘通知处理键盘出现时遮挡控件问题

    -(void)viewDidLoad { NSNotificationCenter *center = [NSNotificationCenter defaultCenter]; //注册键盘显示通知 ...

  10. linux_无秘登录问题(不生效)

    1 . 登录1,执行命令 ssh-keygen -t rsa 之后一路回 车,查看刚生成的无密码钥对: cd .ssh 后 执行 ll 2 .把 id_rsa.pub 追加到授权的 key 里面去. ...