堆排序的链式实现
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;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异