用C++,先输入产生随机数的个数,进行随机数产生的输出,分别用简单选择排序、直接插人排序、冒泡排序、快速排序、两路合并排序以及堆排序进行排序,进行排序结果的输出,若待排序关键字个数为500、10 000、50 000、100 000时,输出每种方法完成排序所需要的时间单位:毫秒)。

时间: 2024-03-22 21:38:52 浏览: 53
CPP

C/C++排序算法实现,冒泡排序、简单选择排序、直接插入排序、希尔排序、堆排序、归并排序、快速排序

好的,这是一个计算机科学方面的问题,我会尽力帮你解答。 首先,我们可以用以下的代码来产生指定个数的随机数并输出: ```c++ #include <iostream> #include <cstdlib> #include <ctime> using namespace std; int main() { int n; cout << "请输入随机数的个数:"; cin >> n; srand(time(NULL)); for (int i = 0; i < n; i++) { cout << rand() << " "; } cout << endl; return 0; } ``` 接着,我们可以分别用以下代码来实现简单选择排序、直接插入排序、冒泡排序、快速排序、两路合并排序以及堆排序: - 简单选择排序: ```c++ void selectionSort(int arr[], int n) { for (int i = 0; i < n - 1; i++) { int minIdx = i; for (int j = i + 1; j < n; j++) { if (arr[j] < arr[minIdx]) { minIdx = j; } } if (minIdx != i) { swap(arr[i], arr[minIdx]); } } } ``` - 直接插入排序: ```c++ void insertionSort(int arr[], int n) { for (int i = 1; i < n; i++) { int temp = arr[i]; int j = i - 1; while (j >= 0 && arr[j] > temp) { arr[j + 1] = arr[j]; j--; } arr[j + 1] = temp; } } ``` - 冒泡排序: ```c++ void bubbleSort(int arr[], int n) { bool flag = true; for (int i = 0; i < n - 1 && flag; i++) { flag = false; for (int j = 0; j < n - 1 - i; j++) { if (arr[j] > arr[j + 1]) { swap(arr[j], arr[j + 1]); flag = true; } } } } ``` - 快速排序: ```c++ int partition(int arr[], int low, int high) { int pivot = arr[high]; int i = low - 1; for (int j = low; j < high; j++) { if (arr[j] < pivot) { i++; swap(arr[i], arr[j]); } } swap(arr[i + 1], arr[high]); return i + 1; } void quickSort(int arr[], int low, int high) { if (low < high) { int pivotPos = partition(arr, low, high); quickSort(arr, low, pivotPos - 1); quickSort(arr, pivotPos + 1, high); } } ``` - 两路合并排序: ```c++ void merge(int arr[], int left, int mid, int right) { int len1 = mid - left + 1; int len2 = right - mid; int *temp1 = new int[len1]; int *temp2 = new int[len2]; for (int i = 0; i < len1; i++) { temp1[i] = arr[left + i]; } for (int j = 0; j < len2; j++) { temp2[j] = arr[mid + 1 + j]; } int i = 0, j = 0, k = left; while (i < len1 && j < len2) { if (temp1[i] <= temp2[j]) { arr[k++] = temp1[i++]; } else { arr[k++] = temp2[j++]; } } while (i < len1) { arr[k++] = temp1[i++]; } while (j < len2) { arr[k++] = temp2[j++]; } delete[] temp1; delete[] temp2; } void mergeSort(int arr[], int left, int right) { if (left < right) { int mid = left + (right - left) / 2; mergeSort(arr, left, mid); mergeSort(arr, mid + 1, right); merge(arr, left, mid, right); } } ``` - 堆排序: ```c++ 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); } } ``` 最后,我们可以用以下代码来测试每种排序方法对于不同规模的数据所需的时间: ```c++ #include <iostream> #include <cstdlib> #include <ctime> using namespace std; void selectionSort(int arr[], int n) { // 简单选择排序 // ... } void insertionSort(int arr[], int n) { // 直接插入排序 // ... } void bubbleSort(int arr[], int n) { // 冒泡排序 // ... } int partition(int arr[], int low, int high) { // 快速排序 // ... } void quickSort(int arr[], int low, int high) { // 快速排序 // ... } void merge(int arr[], int left, int mid, int right) { // 两路合并排序 // ... } void mergeSort(int arr[], int left, int right) { // 两路合并排序 // ... } void heapify(int arr[], int n, int i) { // 堆排序 // ... } void heapSort(int arr[], int n) { // 堆排序 // ... } int main() { int n[] = {500, 10000, 50000, 100000}; for (int i = 0; i < 4; i++) { int *arr = new int[n[i]]; srand(time(NULL)); for (int j = 0; j < n[i]; j++) { arr[j] = rand(); } clock_t start, end; start = clock(); selectionSort(arr, n[i]); end = clock(); cout << "简单选择排序: " << (double)(end - start) / CLOCKS_PER_SEC * 1000 << "ms" << endl; start = clock(); insertionSort(arr, n[i]); end = clock(); cout << "直接插入排序: " << (double)(end - start) / CLOCKS_PER_SEC * 1000 << "ms" << endl; start = clock(); bubbleSort(arr, n[i]); end = clock(); cout << "冒泡排序: " << (double)(end - start) / CLOCKS_PER_SEC * 1000 << "ms" << endl; start = clock(); quickSort(arr, 0, n[i] - 1); end = clock(); cout << "快速排序: " << (double)(end - start) / CLOCKS_PER_SEC * 1000 << "ms" << endl; start = clock(); mergeSort(arr, 0, n[i] - 1); end = clock(); cout << "两路合并排序: " << (double)(end - start) / CLOCKS_PER_SEC * 1000 << "ms" << endl; start = clock(); heapSort(arr, n[i]); end = clock(); cout << "堆排序: " << (double)(end - start) / CLOCKS_PER_SEC * 1000 << "ms" << endl; delete[] arr; } return 0; } ``` 希望这能够对你有所帮助!
阅读全文

相关推荐

最新推荐

recommend-type

排序算法汇总(选择排序 ,直接插入排序,冒泡排序,希尔排序,快速排序,堆排序)

排序算法汇总(选择排序、直接插入排序、冒泡排序、希尔排序、快速排序、堆排序) 本资源介绍了六种常用的排序算法:选择排序、直接插入排序、冒泡排序、希尔排序、快速排序和堆排序。下面对每种算法进行详细介绍:...
recommend-type

利用密码技术或者专门的随机数产生算法产生随机数,并对产生的随机数进行统计分析

实验报告——信息安全技术:随机数产生与统计分析 在信息安全领域,随机数的生成是至关重要的,它在加密、密钥生成、安全协议等方面扮演着基础角色。本实验旨在利用密码技术和标准库函数生成随机数,并对这些随机数...
recommend-type

C语言中用于产生随机数的函数使用方法总结

总的来说,C语言中生成随机数的基本流程是使用`srand()`设置种子,然后用`rand()`获取随机数,根据需要使用模运算来限定随机数的范围。为了得到更好的随机性,可以使用当前时间作为种子,避免使用固定的种子值。对于...
recommend-type

C语言排序题 明明的随机数

然后使用 qsort 函数对数组进行排序,并输出结果。 统计数字 某次科研调查时得到 n 个自然数,每个数均不超过1500000000(1.5*109)。已知不相同的数不超过 10000 个,现在需要统计这些自然数各自出现的次数,并...
recommend-type

C#对list列表进行随机排序的方法

在这个方法中,我们首先检查输入的列表是否为空或只有一个元素,如果是,则直接返回原列表,因为这两种情况无需排序。然后,我们创建一个`Random`对象,用于生成随机数。接着,我们创建一个新的列表`sortedList`,其...
recommend-type

探索AVL树算法:以Faculdade Senac Porto Alegre实践为例

资源摘要信息:"ALG3-TrabalhoArvore:研究 Faculdade Senac Porto Alegre 的算法 3" 在计算机科学中,树形数据结构是经常被使用的一种复杂结构,其中AVL树是一种特殊的自平衡二叉搜索树,它是由苏联数学家和工程师Georgy Adelson-Velsky和Evgenii Landis于1962年首次提出。AVL树的名称就是以这两位科学家的姓氏首字母命名的。这种树结构在插入和删除操作时会维持其平衡,以确保树的高度最小化,从而在最坏的情况下保持对数的时间复杂度进行查找、插入和删除操作。 AVL树的特点: - AVL树是一棵二叉搜索树(BST)。 - 在AVL树中,任何节点的两个子树的高度差不能超过1,这被称为平衡因子(Balance Factor)。 - 平衡因子可以是-1、0或1,分别对应于左子树比右子树高、两者相等或右子树比左子树高。 - 如果任何节点的平衡因子不是-1、0或1,那么该树通过旋转操作进行调整以恢复平衡。 在实现AVL树时,开发者通常需要执行以下操作: - 插入节点:在树中添加一个新节点。 - 删除节点:从树中移除一个节点。 - 旋转操作:用于在插入或删除节点后调整树的平衡,包括单旋转(左旋和右旋)和双旋转(左右旋和右左旋)。 - 查找操作:在树中查找一个节点。 对于算法和数据结构的研究,理解AVL树是基础中的基础。它不仅适用于算法理论的学习,还广泛应用于数据库系统、文件系统以及任何需要快速查找和更新元素的系统中。掌握AVL树的实现对于提升软件效率、优化资源使用和降低算法的时间复杂度至关重要。 在本资源中,我们还需要关注"Java"这一标签。Java是一种广泛使用的面向对象的编程语言,它对数据结构的实现提供了良好的支持。利用Java语言实现AVL树,可以采用面向对象的方式来设计节点类和树类,实现节点插入、删除、旋转及树平衡等操作。Java代码具有很好的可读性和可维护性,因此是实现复杂数据结构的合适工具。 在实际应用中,Java程序员通常会使用Java集合框架中的TreeMap和TreeSet类,这两个类内部实现了红黑树(一种自平衡二叉搜索树),而不是AVL树。尽管如此,了解AVL树的原理对于理解这些高级数据结构的实现原理和使用场景是非常有帮助的。 最后,提及的"ALG3-TrabalhoArvore-master"是一个压缩包子文件的名称列表,暗示了该资源是一个关于AVL树的完整项目或教程。在这个项目中,用户可能可以找到完整的源代码、文档说明以及可能的测试用例。这些资源对于学习AVL树的实现细节和实践应用是宝贵的,可以帮助开发者深入理解并掌握AVL树的算法及其在实际编程中的运用。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【ggplot2绘图技巧】:R语言中的数据可视化艺术

![【ggplot2绘图技巧】:R语言中的数据可视化艺术](https://www.lecepe.fr/upload/fiches-formations/visuel-formation-246.jpg) # 1. ggplot2绘图基础 在本章节中,我们将开始探索ggplot2,这是一个在R语言中广泛使用的绘图系统,它基于“图形语法”这一理念。ggplot2的设计旨在让绘图过程既灵活又富有表现力,使得用户能够快速创建复杂而美观的图形。 ## 1.1 ggplot2的安装和加载 首先,确保ggplot2包已经被安装。如果尚未安装,可以使用以下命令进行安装: ```R install.p
recommend-type

HAL库怎样将ADC两个通道的电压结果输出到OLED上?

HAL库通常是指硬件抽象层(Hardware Abstraction Layer),它是一个软件组件,用于管理和控制嵌入式系统中的硬件资源,如ADC(模拟数字转换器)和OLED(有机发光二极管显示屏)。要将ADC读取的两个通道电压值显示到OLED上,你可以按照以下步骤操作: 1. **初始化硬件**: 首先,你需要通过HAL库的功能对ADC和OLED进行初始化。这包括配置ADC的通道、采样速率以及OLED的分辨率、颜色模式等。 2. **采集数据**: 使用HAL提供的ADC读取函数,读取指定通道的数据。例如,在STM32系列微控制器中,可能会有`HAL_ADC_ReadChannel()
recommend-type

小学语文教学新工具:创新黑板设计解析

资源摘要信息: 本资源为行业文档,主题是设计装置,具体关注于一种小学语文教学黑板的设计。该文档通过详细的设计说明,旨在为小学语文教学场景提供一种创新的教学辅助工具。由于资源的标题、描述和标签中未提供具体的设计细节,我们仅能从文件名称推测文档可能包含了关于小学语文教学黑板的设计理念、设计要求、设计流程、材料选择、尺寸规格、功能性特点、以及可能的互动功能等方面的信息。此外,虽然没有标签信息,但可以推断该文档可能针对教育技术、教学工具设计、小学教育环境优化等专业领域。 1. 教学黑板设计的重要性 在小学语文教学中,黑板作为传统而重要的教学工具,承载着教师传授知识和学生学习互动的重要角色。一个优秀的设计可以提高教学效率,激发学生的学习兴趣。设计装置时,考虑黑板的适用性、耐用性和互动性是非常必要的。 2. 教学黑板的设计要求 设计小学语文教学黑板时,需要考虑以下几点: - 安全性:黑板材质应无毒、耐磨损,边角处理要圆滑,避免在使用中造成伤害。 - 可视性:黑板的大小和高度应适合小学生使用,保证最远端的学生也能清晰看到上面的内容。 - 多功能性:黑板除了可用于书写字词句之外,还可以考虑增加多媒体展示功能,如集成投影幕布或电子白板等。 - 环保性:使用可持续材料,比如可回收的木材或环保漆料,减少对环境的影响。 3. 教学黑板的设计流程 一个典型的黑板设计流程可能包括以下步骤: - 需求分析:明确小学语文教学的需求,包括空间大小、教学方法、学生人数等。 - 概念设计:提出初步的设计方案,并对方案的可行性进行分析。 - 制图和建模:绘制详细的黑板平面图和三维模型,为生产制造提供精确的图纸。 - 材料选择:根据设计要求和成本预算选择合适的材料。 - 制造加工:按照设计图纸和材料标准进行生产。 - 测试与评估:在实际教学环境中测试黑板的使用效果,并根据反馈进行必要的调整。 4. 教学黑板的材料选择 - 传统黑板:传统的黑板多由优质木材和专用黑板漆制成,耐用且书写流畅。 - 绿色环保材料:考虑到环保和学生健康,可以选择无毒或低VOC(挥发性有机化合物)排放的材料。 - 智能材料:如可擦洗的特殊漆料,使黑板表面更加光滑,便于擦拭。 5. 教学黑板的尺寸规格 黑板的尺寸规格应根据实际教室空间和学生的平均身高来设计。一般来说,小学教室的黑板高度应设置在120cm至150cm之间,长度则根据教室墙壁的长度而定,但至少应保证可以容纳整页A4纸的书写空间。 6. 教学黑板的功能性特点 - 书写性能:黑板表面应具备良好的书写性能,使粉笔或马克笔的书写和擦拭都十分顺畅。 - 可视化辅助:集成的可视化工具,如辅助灯、放大镜等,可以帮助教师更有效地展示教学内容。 - 互动性设计:考虑增加互动性元素,例如磁性或可擦写的表面,可以提高学生参与度。 7. 教学黑板的互动功能 随着信息技术的发展,教学黑板可以集成多媒体技术,如触摸屏功能、电子白板功能、互联网接入等,实现与电子设备的互动,从而丰富教学手段,提高教学的趣味性和效率。 综上所述,本资源提供的设计装置文档,聚焦于一种小学语文教学黑板的设计,涵盖了从设计理念到功能实现的全方位内容,旨在通过创新的设计提升小学语文教学的品质和效率。