【数据结构实验】排序(三)快速排序算法的改进(三者取中法)

文章目录

  • 1. 引言
  • 2. 快速排序算法
    • 2.1 传统快速排序
    • 2.2 三者取中法
  • 3. 实验内容
    • 3.1 实验题目
      • (一)输入要求
      • (二)输出要求
    • 3.2 算法实现
  • 4. 实验结果

1. 引言

  快速排序是一种经典的排序算法,其核心思想是通过选择一个基准元素,将数组分为两个部分,左边的元素小于基准,右边的元素大于基准,然后对左右两部分递归地进行排序。然而,在处理基本有序数组时,传统的快速排序可能会退化为 O ( n 2 ) O(n^2) O(n2)的时间复杂度。为了解决这个问题,引入了三者取中法,通过选择数组中的三个元素并取其中值作为基准元素,能够在基本有序的情况下提高排序效率。

2. 快速排序算法

2.1 传统快速排序

  快速排序的核心思想是通过选择一个基准元素,将待排序的数组划分为两个部分,左边的元素小于基准,右边的元素大于基准,然后对左右两部分递归地进行排序,其时间复杂度:

  1. 最好情况: 每次分划都能将数组平均地划分成两部分,此时的时间复杂度为 O ( n l o g 2 n ) O(n log_2 n) O(nlog2n)
  2. 最坏情况: 每次分划都选择了数组中最小(或最大)的元素作为基准,导致每次分划只能减少一个元素,时间复杂度 O ( n 2 ) O(n^2) O(n2)
  3. 平均情况: 通过概率分析,可以证明时间复杂度为 O ( n l o g 2 n ) O(n log_2 n) O(nlog2n)

2.2 三者取中法

2. 算法描述:
  改进的快速排序算法主要区别在于基准元素的选择。在传统快速排序中,通常选择随机元素作为基准,而在改进算法中则采用三者取中法:
在这里插入图片描述
在这里插入图片描述

3. 实验内容

3.1 实验题目

  实现教材233 页下方提及的 Select 算法(求第 4 小元素)(要求文件长度大于等于 5 时调用 Partition2 算法,否则调用直接插入排序算法)。

(一)输入要求

第一组输入数据:
{1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16}
第二组输入数据:
{16,15,14,13,12,11,10,9,8,7,6,5,4,3,2,1}

(二)输出要求

对每组输入数据,输出以下信息(要求必须要有关于输出数据的明确的提示信息)

  1. 输出分划次数;
  2. 输出找到第 4 小元素时文件的状态,即输出此时所有记录的值。

3.2 算法实现

#include<stdio.h>
void Change(int R[],int i,int j)
{int t=R[i];R[i]=R[j];R[j]=t;
}
int Partition2(int R[],int m,int n)
{Change(R,(m+n)/2,m+1);if(R[m+1]>R[n]) Change(R,m+1,n);if(R[m]>R[n]) Change(R,m,n);if(R[m+1]>R[m]) Change(R,m + 1,m);int i=m,j=n+1,K=R[m];while(i<j){i++;while(R[i]<=K) i++;j--;while(R[j]>K) j--;if(i<j)Change(R,i,j);}Change(R,m,j);return j;
}
void InsertSort(int R[],int len)
{int i,j,t;for(i=1;i<len;i++)if(R[i]<R[i-1]){t=R[i];R[i]=R[i-1];for(j=i-1;R[j]>t&&j>=0;j--){R[j+1]=R[j];}R[j+1]=t;}
}
int Select(int R[], int n)
{if(n>=5){int t=Partition2(R,1,n),rounds=0;rounds++;while(t!=4){if(t<4) t=Partition2(R,t+1,n);else t=Partition2(R,1,t-1);rounds++;}printf("分划次数为%d次\n",rounds);printf("找到第4小元素时文件状态为:");int i;for(i=0;i<n;i++)printf("%d ",R[i]);printf("\n");return R[4];}else{InsertSort(R,n);return R[4];}
}
int main()
{//int R[16]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16};int R[16]={16,15,14,13,12,11,10,9,8,7,6,5,4,3,2,1};printf("第4小元素为%d",Select(R,16));return 0;
}
  1. Change 函数用于交换数组中的两个元素。
  2. Partition2 函数使用中值法选择主元,并使用修改过的Lomuto分区方案对数组进行分区。它返回选择的主元的最终位置。
  3. InsertSort 函数对数组执行插入排序。
  4. Select 函数是主要的算法。如果数组的大小大于或等于5,它使用Partition2 函数递归地找到第4小元素。如果大小小于5,它使用 InsertSort 函数对数组进行排序,并返回第4个元素。

4. 实验结果

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/218208.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小程序如何禁止指定用户访问?如何设置指定用户才能访问?

​有些商家为了价格保密或者实行严格的会员制等原因&#xff0c;希望小程序能够限制某些人的访问或者设置指定人员才能访问。这种功能在小程序中&#xff0c;怎么支持这些功能呢&#xff1f;下面具体介绍。 一、禁止指定用户访问 禁止指定用户访问&#xff0c;可以通过小程序…

人工智能面面观

人工智能简介 人工智能&#xff08;Artificial Intelligence&#xff0c;简称AI&#xff09;是一门研究如何使计算机能够模拟和执行人类智能任务的科学和技术领域。它致力于开发能够感知、理解、学习、推理、决策和与人类进行交互的智能系统。人工智能的背景可以追溯到上世纪50…

Python武器库开发-前端篇之CSS元素(三十二)

前端篇之CSS元素(三十二) CSS 元素是一个网页中的 HTML 元素&#xff0c;包括标签、类和 ID。它们可以通过 CSS 选择器选中并设置样式属性&#xff0c;以使网页呈现具有吸引力和良好的可读性。常见的 HTML 元素包括 div、p、h1、h2、span 等&#xff0c;它们可以使用 CSS 设置…

栈和队列OJ题目——C语言

目录 LeetCode 20、有效的括号 题目描述&#xff1a; 思路解析&#xff1a; 解题代码&#xff1a; 通过代码&#xff1a; LeetCode 225、用队列实现栈 题目描述&#xff1a; 思路解析&#xff1a; 解题代码&#xff1a; 通过代码&#xff1a; LeetCode 232、用栈…

【ArcGIS Pro微课1000例】0037:ArcGIS Pro中模型构建器的使用---以shp批量转kml/kmz为例

文章目录 一、ArcGIS Pro模型构建器介绍二、shp批量转kml/kmz1. 打开模型构建器2. 添加工作空间4. 添加【创建要素图层】工具5. 添加【图层转kml】工具6. 输出文件命名7. 运行模型一、ArcGIS Pro模型构建器介绍 模型构建器是一种可视化编程语言,用于构建地理处理工作流。 地理…

【C++】泛型编程 ⑮ ( 类模板示例 - 数组类模板 | 自定义类中持有指针成员变量 )

文章目录 一、支持 数组类模板 存储的 自定义类1、可拷贝和可打印的自定义类2、改进方向3、改进方向 - 构造函数4、改进方向 - 析构函数5、改进方向 - 重载左移运算符6、改进方向 - 重载拷贝构造函数 和 等号运算符 二、代码示例1、Array.h 头文件2、Array.cpp 代码文件3、Test…

PC端从零搭建微信自动回复机器人(一)基础框架搭建及源码

由于工作需要&#xff0c;最近一年一直在研究和使用C#&#xff0c;加上最近工作上有做微信机器人的需要&#xff0c;在已经对接、调试稳定之后&#xff0c;将项目的源码分享给大家&#xff0c;传递开源精神。 一、环境依赖 1、开发工具&#xff1a;Vistual Studio 2022 2、Ne…

什么是自动化测试po模式,po分层如何实现?

一、什么是PO模式 全称&#xff1a;page object model 简称&#xff1a;POM/PO PO模式最核心的思想是分层&#xff0c;实现松耦合&#xff01;实现脚本重复使用&#xff0c;实现脚本易维护性&#xff01; 主要分三层&#xff1a; 1.基础层BasePage&#xff1a;封装一些最基…

SpectralGPT: Spectral Foundation Model 论文翻译1

遥感领域的通用大模型 2023.11.13在CVPR发表 原文地址&#xff1a;[2311.07113] SpectralGPT: Spectral Foundation Model (arxiv.org) 摘要 ​ 基础模型最近引起了人们的极大关注&#xff0c;因为它有可能以一种自我监督的方式彻底改变视觉表征学习领域。虽然大多数基础模型…

云端导览,数字互动 | 拓世法宝AI数字人一体机助力全新旅游时代

《中国旅行消费趋势洞察白皮书&#xff08;2023版&#xff09;》显示&#xff0c;消费者旅行习惯已从“到此一游”变为“深度在地”&#xff0c;更强调在旅游中充实自我、学习新知识。 &#xff08;《中国旅行消费趋势洞察白皮书&#xff08;2023版》截图&#xff09; 从这些资…

【腾讯云 TDSQL-C Serverless 产品测评】深度实测TDSQL-C Serverless 弹性伸缩策略及稳定性

文章目录 前言一、什么是 TDSQL-C Serverless二、TDSQL-C Serverless 的弹性伸缩方案三、弹性伸缩策略及稳定性实测1.测试设计2.测试流程&#xff1a;3.测试准备工作4.开始测试5.测试结果分析5.1.整体过程分析5.2.扩容过程分析5.3.缩容过程分析 四、总结 前言 Serverless 数据…

小白也能看得懂的Jmeter性能测试中服务端资源监控技术

操作步骤&#xff1a; 1、安装插件管理器 插件管理器的作用&#xff1a;可以提供扩展插件的在线安装升级和卸载。因为我们需要在线安装监控插件&#xff0c;首先我们就要先安装插件管理器。 插件管理器的下载地址&#xff1a;https://jmeter-plugins.org/install/Install/ 如…