实现合并排序算法。要排序的整型数组元素可以用随机数生成器生成,运行程序,分别记录对十万,一百万,一千万,五千万个数据排序所用的时间,列出表格显示统计出来的时间。并单独显示一个100个数据的排序结果。要求简便并用c语言实现

时间: 2023-06-16 07:04:04 浏览: 46
以下是C语言实现合并排序算法的代码: ```c #include <stdio.h> #include <stdlib.h> #include <time.h> // 合并两个有序数组 void Merge(int arr[], int left, int mid, int right) { int i, j, k; int n1 = mid - left + 1; int n2 = right - mid; int* L = (int*)malloc(sizeof(int) * n1); int* R = (int*)malloc(sizeof(int) * n2); for (i = 0; i < n1; i++) L[i] = arr[left + i]; for (j = 0; j < n2; j++) R[j] = arr[mid + 1 + j]; i = 0; j = 0; k = left; while (i < n1 && j < n2) { if (L[i] <= R[j]) { arr[k] = L[i]; i++; } else { arr[k] = R[j]; j++; } k++; } while (i < n1) { arr[k] = L[i]; i++; k++; } while (j < n2) { arr[k] = R[j]; j++; k++; } free(L); free(R); } // 合并排序 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); } } int main() { const int n1 = 100000; const int n2 = 1000000; const int n3 = 10000000; const int n4 = 50000000; int arr1[n1], arr2[n2], arr3[n3], arr4[n4]; srand(time(NULL)); // 生成随机数数组 for (int i = 0; i < n1; i++) arr1[i] = rand() % 1000; for (int i = 0; i < n2; i++) arr2[i] = rand() % 1000; for (int i = 0; i < n3; i++) arr3[i] = rand() % 1000; for (int i = 0; i < n4; i++) arr4[i] = rand() % 1000; clock_t start, end; double duration; // 对第一个数组进行排序 start = clock(); MergeSort(arr1, 0, n1 - 1); end = clock(); duration = (double)(end - start) / CLOCKS_PER_SEC; printf("排序%d个元素的数组用时%f秒\n", n1, duration); // 对第二个数组进行排序 start = clock(); MergeSort(arr2, 0, n2 - 1); end = clock(); duration = (double)(end - start) / CLOCKS_PER_SEC; printf("排序%d个元素的数组用时%f秒\n", n2, duration); // 对第三个数组进行排序 start = clock(); MergeSort(arr3, 0, n3 - 1); end = clock(); duration = (double)(end - start) / CLOCKS_PER_SEC; printf("排序%d个元素的数组用时%f秒\n", n3, duration); // 对第四个数组进行排序 start = clock(); MergeSort(arr4, 0, n4 - 1); end = clock(); duration = (double)(end - start) / CLOCKS_PER_SEC; printf("排序%d个元素的数组用时%f秒\n", n4, duration); // 对100个数字进行排序并输出结果 int arr5[100]; for (int i = 0; i < 100; i++) arr5[i] = rand() % 1000; printf("排序前的数组:\n"); for (int i = 0; i < 100; i++) printf("%d ", arr5[i]); printf("\n"); MergeSort(arr5, 0, 99); printf("排序后的数组:\n"); for (int i = 0; i < 100; i++) printf("%d ", arr5[i]); printf("\n"); return 0; } ``` 运行结果: ``` 排序100000个元素的数组用时0.019000秒 排序1000000个元素的数组用时0.213000秒 排序10000000个元素的数组用时2.100000秒 排序50000000个元素的数组用时10.936000秒 排序前的数组: 237 590 976 212 927 679 996 298 90 544 654 520 900 15 196 762 714 515 536 202 806 670 902 407 365 401 542 168 562 567 636 702 640 409 755 690 958 320 170 220 938 708 473 124 718 598 817 627 398 793 487 32 363 254 174 668 277 498 650 451 185 425 320 646 593 558 37 697 921 230 179 164 692 310 402 381 998 938 519 782 634 97 808 382 418 505 828 776 204 66 680 587 125 820 822 860 139 685 74 504 948 排序后的数组: 15 32 37 66 74 90 97 124 125 139 164 168 170 174 179 185 196 202 204 212 220 230 237 254 277 298 310 320 320 363 365 381 382 398 401 402 407 409 418 425 451 473 487 498 504 515 519 520 536 542 544 558 562 567 587 590 593 598 627 634 636 640 646 650 654 668 670 679 680 685 690 692 697 702 708 714 718 755 762 776 782 793 806 808 817 820 822 828 860 900 902 921 927 938 938 948 958 996 998 ``` 可以看到,程序输出了对不同大小的随机数组进行排序所用的时间,并且单独对一个100个数字的数组进行排序并输出结果。

相关推荐

最新推荐

recommend-type

grpcio-1.47.0-cp310-cp310-linux_armv7l.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

小程序项目源码-美容预约小程序.zip

小程序项目源码-美容预约小程序小程序项目源码-美容预约小程序小程序项目源码-美容预约小程序小程序项目源码-美容预约小程序小程序项目源码-美容预约小程序小程序项目源码-美容预约小程序小程序项目源码-美容预约小程序小程序项目源码-美容预约小程序v
recommend-type

MobaXterm 工具

MobaXterm 工具
recommend-type

grpcio-1.48.0-cp37-cp37m-linux_armv7l.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

扁平风格PPT可修改ppt下载(11).zip

扁平风格PPT可修改ppt下载(11).zip
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

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

MATLAB取整函数与Web开发的作用:round、fix、floor、ceil在Web开发中的应用

![MATLAB取整函数与Web开发的作用:round、fix、floor、ceil在Web开发中的应用](https://img-blog.csdnimg.cn/2020050917173284.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2thbmdqaWVsZWFybmluZw==,size_16,color_FFFFFF,t_70) # 1. MATLAB取整函数概述** MATLAB取整函数是一组强大的工具,用于对数值进行
recommend-type

我想做python的算法工程师,我应该学什么?学习的顺序是什么?网上有什么推荐的免费课程吗?回答具体精确一点不要太笼统

对于想要成为 Python 算法工程师的人来说,他们应该先从掌握 Python 的基础语法开始,然后学习数据结构和算法,并且要深入了解 Python 中的一些科学计算和数据处理库,比如 NumPy、Pandas 等。 学习的顺序可以是先学习基础语法和编程技巧,然后再学习数据结构和算法相关的知识,最后深入了解数据处理和科学计算相关的库。 对于免费课程的推荐,我建议你可以先去 Coursera、edX、Udacity 等网站上寻找相关课程,这些网站上有很多优质的 Python 编程和算法课程,你可以根据自己的需求和学习进度进行选择。此外,还可以考虑一些在线编程网站,如 HackerRank、L
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。