当前位置: 首页 > news >正文

6-6 堆排序 分数 10

在这里插入图片描述

typedef int Datatype;
typedef struct 
{Datatype* elem; int Length;
}SqList;
typedef SqList HeapType;
void swap(int* a, int* b)
{int tmp = *a;*a = *b;*b = tmp;
}
//建大堆
//m: 结点个数 s: 待下调父结点下标
void HeapAdjust(HeapType H, int s, int m) 
{int child = s * 2;while(child <= m){												if (child + 1 <= m && H.elem[child] < H.elem[child + 1])++child;		if (H.elem[s] < H.elem[child]){swap(&H.elem[child], &H.elem[s]);s = child;child = s * 2;}elsebreak;}                			
}
// int parent = (child - 1) / 2   // int parent = child / 2  
// int child = parent * 2 + 1;    // int child = parent * 2 ;void HeapSort(HeapType H)
{ //下调建堆for (int i = H.Length / 2; i >= 1; i--){HeapAdjust(H, i, H.Length);}//排序: 依次把堆顶放到表尾for (int end = H.Length; end >= 2; end--){swap(&H.elem[1], &H.elem[end]);HeapAdjust(H, 1, end - 1);}
}
int main()
{HeapType L;//CreatSqList(&L);HeapSort(L);for (int i = 1; i <= L.Length; i++){printf("%d ", L.elem[i]);}return 0;
}
http://www.lryc.cn/news/259696.html

相关文章:

  • 高翔《自动驾驶与机器人中的SLAM技术》第九、十章载入静态地图完成点云匹配重定位
  • 英语六级翻译
  • VMware配置Ubuntu虚拟机
  • Backtrader 文档学习-Platform Concepts
  • 策略模式(常用)
  • Express中使用Swagger
  • 【C++】单一职责模式
  • GPT4-隐者地址
  • 教师考编需要什么条件
  • 刘家窑中医医院鲁卫星主任:冬季守护心脑血管,为社区居民送去健康关爱
  • 专家级定位咨询:打造不可复制的市场地位
  • 为什么说代码注释是程序员必备的技能?
  • 日期——年月日星期时间封装和年月日时间封装
  • RK3568全国产化多网口板卡带poe供电,支持鸿蒙麒麟系统
  • UI卡顿问题
  • Linux操作系统的ECS云服务器上搭建WordPress网站教程
  • 【Linux】多线程相关问题
  • GPS北斗卫星时空信号安全防护装置(授时)介绍
  • redis:一、面试题常见分类+缓存穿透的定义、解决方案、布隆过滤器的原理和误判现象、面试回答模板
  • 智慧公交:提高城市出行效率的数字化之路
  • Linux - 内存 - memblock 分配器
  • SQL、Jdbc、JdbcTemplate、Mybatics
  • 四六级高频词组8
  • fastapi-amis-admin快速创建一个后台管理系统增加音乐管理功能(3)
  • 全球化需要先搬离中国?中国公司出海不应失去“模式自信”
  • 三大维度解码剑南春“高质量发展”丨年度盘点
  • 外包干了3个月,技术退步明显.......
  • 思福迪运维安全管理系统 test_qrcode_b RCE漏洞复现
  • Salesforce×阿里云,影响几何?
  • Qt对excel操作