用c语言写出比较归并排序和快速排序的关键字比较次数和关键字移动次数的代码,要求待排序的表长不能小于100;其中的数据要用伪随机数生成程序产生至少要用5组不同的输入数据比较

时间: 2023-12-20 12:05:31 浏览: 23
以下是用C语言实现比较归并排序和快速排序的代码,并计算关键字比较次数和关键字移动次数,同时使用伪随机数生成程序产生5组不同的输入数据进行比较: ``` #include <stdio.h> #include <stdlib.h> #include <time.h> void merge(int arr[], int l, int m, int r, int* comp, int* move) { int i, j, k; int n1 = m - l + 1; int n2 = r - m; int L[n1], R[n2]; for (i = 0; i < n1; i++) L[i] = arr[l + i]; for (j = 0; j < n2; j++) R[j] = arr[m + 1 + j]; i = 0; j = 0; k = l; while (i < n1 && j < n2) { (*comp)++; if (L[i] <= R[j]) { arr[k] = L[i]; (*move)++; i++; } else { arr[k] = R[j]; (*move)++; j++; } k++; } while (i < n1) { arr[k] = L[i]; (*move)++; i++; k++; } while (j < n2) { arr[k] = R[j]; (*move)++; j++; k++; } } void mergeSort(int arr[], int l, int r, int* comp, int* move) { if (l < r) { int m = l + (r - l) / 2; mergeSort(arr, l, m, comp, move); mergeSort(arr, m + 1, r, comp, move); merge(arr, l, m, r, comp, move); } } void swap(int* a, int* b, int* move) { int t = *a; *a = *b; *b = t; (*move)++; } int partition(int arr[], int low, int high, int* comp, int* move) { int pivot = arr[high]; int i = (low - 1); for (int j = low; j <= high - 1; j++) { (*comp)++; if (arr[j] < pivot) { i++; swap(&arr[i], &arr[j], move); } } swap(&arr[i + 1], &arr[high], move); return (i + 1); } void quickSort(int arr[], int low, int high, int* comp, int* move) { if (low < high) { int pi = partition(arr, low, high, comp, move); quickSort(arr, low, pi - 1, comp, move); quickSort(arr, pi + 1, high, comp, move); } } void printArray(int arr[], int n) { for (int i = 0; i < n; i++) printf("%d ", arr[i]); printf("\n"); } int main() { srand(time(NULL)); int n = 100; int comp, move; for (int i = 0; i < 5; i++) { printf("Input %d:\n", i + 1); int arr[n]; for (int j = 0; j < n; j++) arr[j] = rand() % 1000; comp = move = 0; mergeSort(arr, 0, n - 1, &comp, &move); printf("After Merge Sort:\n"); printArray(arr, n); printf("Number of comparisons: %d\n", comp); printf("Number of moves: %d\n", move); comp = move = 0; quickSort(arr, 0, n - 1, &comp, &move); printf("After Quick Sort:\n"); printArray(arr, n); printf("Number of comparisons: %d\n", comp); printf("Number of moves: %d\n", move); printf("\n"); } return 0; } ``` 注意:以上代码中使用了伪随机数生成程序产生5组不同的输入数据进行比较,每次运行结果可能会有所不同。

相关推荐

最新推荐

recommend-type

c语言编程的几种排序算法比较

排序算法是一种基本并且常用的算法。由于实际工作中处理的数量巨大,所以排序算法 对算法本身的速度要求很高。 而一般我们所谓的算法的性能主要是指算法的复杂度,一般用O方法来表示。在后面我将 给出详细的说明。
recommend-type

C语言实现排序算法之归并排序详解

主要介绍了C语言实现排序算法之归并排序,对归并排序的原理及实现过程做了非常详细的解读,需要的朋友可以参考下
recommend-type

用C语言实现从文本文件中读取数据后进行排序的功能

是一个十分可靠的程序,这个程序的查错能力非常强悍。程序包含了文件操作,归并排序和字符串输入等多种技术。对大家学习C语言很有帮助,有需要的一起来看看。
recommend-type

用C语言实现成绩表的快速排序程序设计

问题描述〕给出n个学生的1门课程的考试成绩信息,每条信息由姓名 与分数组成,要求设计快速排序算法,进行: (1)按成绩排序; (2)输出形式为:张强 张平 曾芽 王华 孙军 李应 程滨 90 88 82 78 70 69 65 〔...
recommend-type

详解C语言正确使用extern关键字

主要介绍了C语言正确使用extern关键字,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
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

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

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