堆排序的链式实现

简介: 堆排序的链式实现

GCC编译通过:

#include <stdio.h>
#include <stdlib.h>
#define N 10
#define MAX 100
typedef struct node{
    int data;
    struct node *left;
    struct node *right;
}BTnode;
BTnode *queue[N+1];
int rear=0,front=0;
void PHeap(BTnode *r)
{
    BTnode *t;
    int flag=1;
    int tt,k;
        while(flag){
        flag=0;
        for(t=queue[front],k=front;k;k--){
            t=queue[k];
            if(t->left->data>t->data){
                tt=t->data;
                t->data=t->left->data;
                t->left->data=tt;
                flag=1;
            }
            if(t->right&&t->right->data>t->data){
                tt=t->data;
                t->data=t->right->data;
                t->right->data=tt;
                flag=1; 
            }
        }//for
        }//while(flag)
}
BTnode *Sort(BTnode *root)
{
    while(front>=1){
    PHeap(root); 
        printf("%5d",root->data);
        root->data=queue[rear]->data;
        if(rear%2) queue[rear/2]->right=NULL;
        else{
            queue[rear/2]->left=NULL;
            if(front==1) printf("%5d",root->data);
            front--;
        }  
        rear--; 
    }
}
BTnode *deal(int a[],int n)
{
    int i;
    BTnode *root;
    /*按层,使用队列*/ 
  for(i=0;i<n;i++){
    /*初始化新节点*/ 
  BTnode *t=(BTnode *)malloc(sizeof(BTnode));
  t->left=t->right=NULL;
  t->data=a[i];
   /*入队*/
   queue[++rear]=t; 
  if(i==0){
    root=t;
    front++;
  }else{
     if(!queue[front]->left){
        queue[front]->left=t;
     }else{
        queue[front]->right=t;
        front++;
     }  
  }
  }
  return root;  
}
/*按层输出二叉树*/
void PrintTree(BTnode *root)
{
     BTnode *t=NULL;
     BTnode *queue[MAX];
     int front=0,rear=0;
     /*入队*/
     queue[++rear]=root;
     /*出队*/
     while(front!=rear){    
     t=queue[++front]; 
     printf("%d",t->data);
     if(t->left) queue[++rear]=t->left;
     if(t->right) queue[++rear]=t->right;
     }
     putchar('\n');
} 
int main(void)
{
    int a[N]={1,3,5,7,9,2,4,6,8,10};
    BTnode *root=NULL;
    root=deal(a,N);
    PrintTree(root);
    Sort(root);
    return 0;
}
相关文章
|
5月前
|
存储 算法 搜索推荐
【数据结构】归并排序的非递归写法和计数排序
【数据结构】归并排序的非递归写法和计数排序
|
5月前
|
存储 算法 C语言
数据结构和算法——堆排序(选择排序、思路图解、代码、时间复杂度、堆排序及代码)
数据结构和算法——堆排序(选择排序、思路图解、代码、时间复杂度、堆排序及代码)
36 0
|
5月前
|
测试技术
深入理解数据结构第二弹——二叉树(2)——堆排序及其时间复杂度
深入理解数据结构第二弹——二叉树(2)——堆排序及其时间复杂度
59 0
|
5月前
|
算法 C语言
数据结构和算法——归并排序(有序子列的归并、递归算法、非递归算法、思路图解、C语言代码)
数据结构和算法——归并排序(有序子列的归并、递归算法、非递归算法、思路图解、C语言代码)
30 0
|
存储 算法 搜索推荐
数据结构各内部排序算法总结对比及动图演示(插入排序、冒泡和快速排序、选择排序、堆排序、归并排序和基数排序等)2
数据结构各内部排序算法总结对比及动图演示(插入排序、冒泡和快速排序、选择排序、堆排序、归并排序和基数排序等)2
253 0
|
6月前
|
存储 算法
【链式二叉树】数据结构链式二叉树的(万字详解)
【链式二叉树】数据结构链式二叉树的(万字详解)
|
6月前
|
算法 搜索推荐 C语言
C语言数据结构之排序整合与比较(冒泡,选择,插入,希尔,堆排序,快排及改良,归并排序,计数排序)
C语言数据结构之排序整合与比较(冒泡,选择,插入,希尔,堆排序,快排及改良,归并排序,计数排序)
|
11月前
|
算法 编译器
【数据结构】归并排序 的递归实现与非递归实现
【数据结构】归并排序 的递归实现与非递归实现
113 1
|
6月前
|
搜索推荐
排序算法:快速排序(三种排序方式、递归和非递归)
排序算法:快速排序(三种排序方式、递归和非递归)
129 0
|
存储 算法 搜索推荐
数据结构各内部排序算法总结对比及动图演示(插入排序、冒泡和快速排序、选择排序、堆排序、归并排序和基数排序等)1
数据结构各内部排序算法总结对比及动图演示(插入排序、冒泡和快速排序、选择排序、堆排序、归并排序和基数排序等)1
196 0