c++对一含有n(n<=100)个整数的序列,使用堆排序将其由小到大(非降序)排序

时间: 2023-06-16 16:04:06 浏览: 32
堆排序(Heap Sort)是一种树形选择排序,是对直接选择排序的有效改进。 堆排序的基本思想是:将待排序序列构造成一个大根堆(或小根堆),此时整个序列的最大值(或最小值)就是堆顶的根节点。将其与末尾元素进行交换,此时末尾就为最大值(或最小值)。然后将剩余n-1个元素重新构造成一个堆,这样就会得到n个元素的次小值。如此反复执行,便能得到一个有序序列了。 以下是C++代码实现: ``` #include <iostream> using namespace std; // 堆筛选,调整堆 void heapify(int arr[], int n, int i) { int largest = i; // 初始化最大元素为根节点 int l = 2 * i + 1; // 左子节点 int r = 2 * i + 2; // 右子节点 // 如果左子节点比根节点大,则更新最大元素 if (l < n && arr[l] > arr[largest]) largest = l; // 如果右子节点比根节点大,则更新最大元素 if (r < n && arr[r] > arr[largest]) largest = r; // 如果最大元素不是根节点,则交换根节点和最大元素 if (largest != i) { swap(arr[i], arr[largest]); // 继续调整堆 heapify(arr, n, largest); } } // 堆排序 void heapSort(int arr[], int n) { // 构造大根堆(从最后一个非叶子节点开始) for (int i = n / 2 - 1; i >= 0; i--) heapify(arr, n, i); // 一个一个从堆顶取出元素 for (int i = n - 1; i >= 0; i--) { // 将堆顶元素与末尾元素交换 swap(arr[0], arr[i]); // 调整堆(从根节点开始) heapify(arr, i, 0); } } int main() { int n; int arr[100]; cout << "请输入序列长度n(n<=100):"; cin >> n; cout << "请输入" << n << "个整数:"; for (int i = 0; i < n; i++) cin >> arr[i]; heapSort(arr, n); cout << "排序后的序列为:"; for (int i = 0; i < n; i++) cout << arr[i] << " "; return 0; } ``` 注意:堆排序的时间复杂度为O(nlogn),空间复杂度为O(1)。

相关推荐

以下是C++代码实现: c++ #include <iostream> #include <vector> using namespace std; // 构造最大堆 void buildMaxHeap(vector<int>& nums) { int n = nums.size(); for (int i = n / 2 - 1; i >= 0; i--) { // 从最后一个非叶子节点开始向下调整 int parent = i; int leftChild = parent * 2 + 1; while (leftChild < n) { int rightChild = parent * 2 + 2; int maxChild = leftChild; if (rightChild < n && nums[rightChild] > nums[leftChild]) { maxChild = rightChild; } if (nums[maxChild] > nums[parent]) { swap(nums[parent], nums[maxChild]); parent = maxChild; leftChild = parent * 2 + 1; } else { break; } } } } // 堆排序 void heapSort(vector<int>& nums) { int n = nums.size(); for (int i = n - 1; i >= 1; i--) { swap(nums[0], nums[i]); // 将当前最大值放到末尾 int parent = 0; int leftChild = parent * 2 + 1; while (leftChild < i) { // 从根节点开始向下调整 int rightChild = parent * 2 + 2; int maxChild = leftChild; if (rightChild < i && nums[rightChild] > nums[leftChild]) { maxChild = rightChild; } if (nums[maxChild] > nums[parent]) { swap(nums[parent], nums[maxChild]); parent = maxChild; leftChild = parent * 2 + 1; } else { break; } } } } int main() { int n; cin >> n; vector<int> nums(n); for (int i = 0; i < n; i++) { cin >> nums[i]; } // 堆排序前 for (int i = 0; i < n; i++) { cout << nums[i]; if (i < n - 1) { cout << " "; } } cout << endl; // 构造最大堆 buildMaxHeap(nums); // 构造堆后 for (int i = 0; i < n; i++) { cout << nums[i]; if (i < n - 1) { cout << " "; } } cout << endl; // 堆排序后 heapSort(nums); for (int i = 0; i < n; i++) { cout << nums[i]; if (i < n - 1) { cout << ","; } } cout << endl; return 0; } 输入示例: 8 3 1 4 1 5 9 2 6 输出示例: 3 1 4 1 5 9 2 6 9 5 4 6 1 3 2 1 1,1,2,3,4,5,6,9

最新推荐

C++通过自定义函数找出一个整数数组中第二大数的方法

主要介绍了C++通过自定义函数找出一个整数数组中第二大数的方法,涉及C++针对数组的遍历操作相关技巧,需要的朋友可以参考下

C++实现对输入数字组进行排序

里给大家介绍的是通过某个方法实现判断命令行中输入的数字是几个,这样再用冒泡法排序的时候就不用担心输入的是几个数字,用到的知识主要是冒泡法排序

C++实现八个常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序等

本文实现了八个常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序 、快速排序、归并排序、堆排序和LST基数排序 首先是算法实现文件Sort.h,代码如下: /* * 实现了八个常用的排序算法:插入排序、冒泡排序...

C++使用递归和非递归算法实现的二叉树叶子节点个数计算方法

主要介绍了C++使用递归和非递归算法实现的二叉树叶子节点个数计算方法,涉及C++二叉树的定义、遍历、统计相关操作技巧,需要的朋友可以参考下

2023年全球聚甘油行业总体规模.docx

2023年全球聚甘油行业总体规模.docx

超声波雷达驱动(Elmos524.03&amp;Elmos524.09)

超声波雷达驱动(Elmos524.03&Elmos524.09)

ROSE: 亚马逊产品搜索的强大缓存

89→ROSE:用于亚马逊产品搜索的强大缓存Chen Luo,Vihan Lakshman,Anshumali Shrivastava,Tianyu Cao,Sreyashi Nag,Rahul Goutam,Hanqing Lu,Yiwei Song,Bing Yin亚马逊搜索美国加利福尼亚州帕洛阿尔托摘要像Amazon Search这样的产品搜索引擎通常使用缓存来改善客户用户体验;缓存可以改善系统的延迟和搜索质量。但是,随着搜索流量的增加,高速缓存不断增长的大小可能会降低整体系统性能。此外,在现实世界的产品搜索查询中广泛存在的拼写错误、拼写错误和冗余会导致不必要的缓存未命中,从而降低缓存 在本文中,我们介绍了ROSE,一个RO布S t缓存E,一个系统,是宽容的拼写错误和错别字,同时保留传统的缓存查找成本。ROSE的核心组件是一个随机的客户查询ROSE查询重写大多数交通很少流量30X倍玫瑰深度学习模型客户查询ROSE缩短响应时间散列模式,使ROSE能够索引和检

java中mysql的update

Java中MySQL的update可以通过JDBC实现。具体步骤如下: 1. 导入JDBC驱动包,连接MySQL数据库。 2. 创建Statement对象。 3. 编写SQL语句,使用update关键字更新表中的数据。 4. 执行SQL语句,更新数据。 5. 关闭Statement对象和数据库连接。 以下是一个Java程序示例,用于更新MySQL表中的数据: ```java import java.sql.*; public class UpdateExample { public static void main(String[] args) { String

JavaFX教程-UI控件

JavaFX教程——UI控件包括:标签、按钮、复选框、选择框、文本字段、密码字段、选择器等

社交网络中的信息完整性保护

141社交网络中的信息完整性保护摘要路易斯·加西亚-普埃约Facebook美国门洛帕克lgp@fb.com贝尔纳多·桑塔纳·施瓦茨Facebook美国门洛帕克bsantana@fb.com萨曼莎·格思里Facebook美国门洛帕克samguthrie@fb.com徐宝轩Facebook美国门洛帕克baoxuanxu@fb.com信息渠道。这些网站促进了分发,Facebook和Twitter等社交媒体平台在过去十年中受益于大规模采用,反过来又助长了传播有害内容的可能性,包括虚假和误导性信息。这些内容中的一些通过用户操作(例如共享)获得大规模分发,以至于内容移除或分发减少并不总是阻止其病毒式传播。同时,社交媒体平台实施解决方案以保持其完整性的努力通常是不透明的,导致用户不知道网站上发生的任何完整性干预。在本文中,我们提出了在Facebook News Feed中的内容共享操作中添加现在可见的摩擦机制的基本原理,其设计和实现挑战,以�