41.排序练习题(王道2023数据结构第8章综合练习)

试题1(王道8.3.3节综合练习2):

编写双向冒泡排序算法,在正反两个方向交替扫描。即第一趟把关键字最大的元素放在序列的最后面,第二趟把关键字最小的元素放在序列最前面,如此反复。

首先实现冒泡排序:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>#define ElemType intvoid BubbleSort(ElemType a[],int n){int x;bool flag = false;for (int i = 0; i < n;i++){flag = false;for (int j = n - 1; j > i;j--){if(a[j-1] > a[j]){x = a[j - 1];a[j - 1] = a[j];a[j] = x;flag = true;}}if (flag == false)return;}
}int main(){int a[7] = {4, 3, 2, 7, 6, 8, 9};BubbleSort(a, 7);for (int i = 0; i < 7;i++){printf("%d ", a[i]);}
}

输出:

2 3 4 6 7 8 9 

然后实现所谓的双向:把i%2这个条件加上去即可:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>#define ElemType intvoid BubbleSort(ElemType a[],int n){int x;bool flag = false;for (int i = 0; i < n;i++){if(i % 2 == 0){for (int j = 0; j < n - 1 - i; j++){if(a[j] > a[j+1]){x = a[j + 1];a[j + 1] = a[j];a[j] = x;flag = true;}}if (flag == false)return;}else{for (int j = n - 1; j > i;j--){if(a[j-1] > a[j]){x = a[j - 1];a[j - 1] = a[j];a[j] = x;flag = true;}}if (flag == false)return;}}
}int main(){int a[7] = {4, 3, 2, 9, 8, 7, 6};BubbleSort(a, 7);for (int i = 0; i < 7;i++){printf("%d ", a[i]);}
}

试题2(王道8.3.3节综合练习3):

已知线性表按顺序存储,且每个元素都是不相同的整数类型元素,设计把所有奇数移动到所有偶数前边的算法(要求时间最少,辅助空间最少)。

本题可使用类似快排的思想:

#define ElemType int
void oddbeforeeven(ElemType a[],int n){int low = 0;int high = n - 1;int change;while(low < high){while(a[low] % 2 != 0){  //前面是奇数low = low + 1;}while(a[high] % 2 == 0){  //后面是偶数high = high - 1;}change = a[high];a[high] = a[low];a[low] = change;low = low + 1;  //注意后面必须在移动一下指针high = high - 1;}
}int main(){int a[7] = {4, 3, 2, 9, 8, 7, 6};oddbeforeeven(a, 7);for (int i = 0; i < 7;i++){printf("%d ", a[i]);}
}

输出:

7 3 9 2 8 4 6

试题3(王道8.3.3节综合练习5):

试编写一个算法,在数组中找到第k小的元素。

此题可参考王道第七章的二叉排序树的练习(王道7.3.4节综合练习11):

【试题再现】编写一个递归算法,在一棵具有n个结点的二叉排序树上查找第k小的元素,并返回该结点的指针。要求算法的平均时间复杂度是,二叉排序树每个结点中除了data,lchild,rchild外,增设一个count成员,保存以该结点为根的子树的结点个数。

我们首先实现一下快速排序:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>#define ElemType int
int Partition(ElemType a[],int low,int high){ElemType pivot = a[low];while(low < high){while(low<high&&a[high]>=pivot)high = high - 1;a[low] = a[high];while(low<high&&a[low]<=pivot)low = low + 1;a[high] = a[low];}a[low] = pivot;return low;
}
void QuickSort(ElemType a[],int low,int high){if(low<high){int pivotpos = Partition(a, low, high);QuickSort(a, low, pivotpos - 1);QuickSort(a, pivotpos + 1, high);}
}int main(){int a[7] = {4, 3, 2, 9, 8, 7, 6};QuickSort(a, 0, 6);for (int i = 0; i < 7;i++){printf("%d ", a[i]);}
}

当快速排序结果出来后依次输出可以直接得到答案。这里也可以递归:

#define ElemType int
int Partition(ElemType a[],int low,int high){ElemType pivot = a[low];while(low < high){while(low < high && a[high] >= pivot)high = high - 1;a[low] = a[high];while(low < high && a[low] <= pivot)low = low + 1;a[high] = a[low];}a[low] = pivot;return low;  //返回pivot的下标
}int QuickSortk(ElemType a[],int low,int high,int k){int pivotpos = Partition(a, low, high);if(pivotpos == k-1){printf("%d\n", a[pivotpos]);return a[pivotpos];}else if(pivotpos > k-1){return QuickSortk(a, low, pivotpos - 1, k);}else{return QuickSortk(a, pivotpos + 1, high, k);}
}int main(){int a[10] = {4, 3, 2, 9, 8, 7, 6, 10, 14, 17};QuickSortk(a, 0, 9, 6);for (int i = 0; i < 10;i++){printf("%d ", a[i]);}
}

输出:

8
2 3 4 6 7 8 9 10 14 17

试题4(王道8.3.3节综合练习6):

荷兰国旗问题。

分类讨论,这题可能不是那么好想,一点点调吧...

#include<stdio.h>
#include<stdlib.h>
#include<string.h>#define ElemType int
int NetherlandsFlag(ElemType a[],int n){int red = -1;int blue = n;int x;for (int i = 0; i < n;i++){if(i < blue){if(a[i] == 0){  //i之前全部是红或白x = a[i];a[i] = a[red + 1];a[red + 1] = x;red = red + 1;}else if(a[i] == 2){while(a[blue - 1] == 2){blue = blue - 1;}if(i < blue){x = a[i];a[i] = a[blue - 1];a[blue - 1] = x;blue = blue - 1;if(a[i] == 0){  //红色的交换到前面x = a[i];a[i] = a[red + 1];a[red + 1] = x;red = red + 1;}}}}elsebreak;}
}int main(){int a[11] = {2, 1, 0, 0, 2, 1, 1, 0, 0, 2, 1}; // 0,1,2代表红白蓝NetherlandsFlag(a, 11);for (int i = 0; i < 11;i++){printf("%d ", a[i]);}
}

输出:

0 0 0 0 1 1 1 1 2 2 2 

试题5(王道8.3.3节综合练习7):

解答:把试题3的代码参数k换成\left \lfloor n/2 \right \rfloor即可。

试题6(王道8.6.3节综合练习2):

设顺序表用数组A[ ]表示,表中元素存储在数组下标1到m+n范围内,前m个元素递增有序,后n个元素也递增有序,设计算法使得整个顺序表有序。

可以看成直接插入排序进行了m轮,然后在进行n轮直接插入排序:

#define ElemType int
int Sort(ElemType a[],int m,int n){int i,k;for (int i = m + 1; i <= m + n;i++){a[0] = a[i];  //复制到a[0]for (k = i - 1; a[k] > a[0]; k--){ // 移动a[k + 1] = a[k];}a[k + 1] = a[0];}
}int main(){int a[9] = {0,2,4,5,7,3,5,9,11}; Sort(a, 4, 4);for (int i = 1; i <= 8;i++){printf("%d ", a[i]);}
}

输出:

2 3 4 5 5 7 9 11

试题7(王道8.6.3节综合练习3):

有一种简单的排序算法,叫做计数排序。这种排序算法对一个待排序的表进行排序,并将排序结果存放在另一个新的表中。必须注意的是,表中所有待排序的关键字互不相同。计数排序算法针对表中的每一个记录,遍历待排序的表一遍,统计表中有多少个记录的关键字比该记录的关键字小。假如针对某一个记录,统计出计数值为c,那么,这个记录在新的有序表中合适的存放位置即为c。设计实现计数排序的算法。

#define ElemType int
int Sort(ElemType a[],ElemType b[]){int count = 0;for (int i = 0; i < 10;i++){count = 0;for (int j = 0; j < 10;j++){if(a[j]<a[i])count++;}b[count] = a[i];}
}int main(){int a[10] = {0,4,3,2,6,9,8,11,32,21}; int b[10];Sort(a, b);for (int i = 0; i <= 9;i++){printf("%d ", b[i]);}
}

试题8(王道8.6.3节综合练习4):

设有一个数组的存放一个无序关键序列K_1,K_2...K_n,现在要求把最后一个元素K_n放在将元素排序后的正确位置上,试编写实现该功能的算法,要求比较关键字的次数不超过n。

可以用上题的思路,也可借助快速排序。

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

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

相关文章

企业多部门VLAN间互访部署实战

1. 二层VLAN技术部署回顾&#xff1b; 2. 三层交换机上如何部署VLAN&#xff1f; 3. 部署VLAN的过程中有哪些注意事项&#xff1f; -- VLAN技术 - 虚拟局域网 -- 局域网 - 通过交换机连接的网络 -- VLAN - 把一个大的局域网 做一个分割 -- 常见局域网的问题&a…

信号类型(通信)——QAM调制信号

系列文章目录 《信号类型&#xff08;通信&#xff09;——仿真》 文章目录 前言 一、原理图 二、仿真 2.1、QAM仿真 2.2、不同滚降系数 2.3、不同M下QAM调制对比 总结 前言 本文主要结合仿真分析了QAM的信号处理过程&#xff0c;并简单分析了成型滤波器中的滚降系数对QA…

基于深度学习的中文情感分类 - 卷积神经网络 情感分类 情感分析 情感识别 评论情感分类 计算机竞赛

文章目录 1 前言2 情感文本分类2.1 参考论文2.2 输入层2.3 第一层卷积层&#xff1a;2.4 池化层&#xff1a;2.5 全连接softmax层&#xff1a;2.6 训练方案 3 实现3.1 sentence部分3.2 filters部分3.3 featuremaps部分3.4 1max部分3.5 concat1max部分3.6 关键代码 4 实现效果4.…

【Proteus仿真】【Arduino单片机】简易电子琴

文章目录 一、功能简介二、软件设计三、实验现象联系作者 一、功能简介 本项目使用Proteus8仿真Arduino单片机控制器&#xff0c;使用无源蜂鸣器、按键等。 主要功能&#xff1a; 系统运行后&#xff0c;按下K1-K7键发出不同音调。 二、软件设计 /* 作者&#xff1a;嗨小易&a…

基于 Center 的 3D 目标检测和跟踪

论文地址&#xff1a;https://arxiv.org/abs/2006.11275 论文代码&#xff1a;https://github.com/tianweiy/CenterPoint 3D 目标通常表示为点云中的 3D Boxes。 CenterPoint 在第一阶段&#xff0c;使用关键点检测器检测对象的中心&#xff0c;然后回归到其他属性&#xff0…

CSAPP BOMB LAB

BOMB LAB lab phase1 bomb.c phase1 code: bomb.s phase1 code: 401338 对应 string_not_equal函数: 工具介绍 objdump 使用 objdump是一个用于分析可执行文件、目标文件和共享库的工具。它可以显示这些文件的二进制指令、符号表、段信息、重定位表等内容&#xff0c;帮…

C++的拷贝构造函数

目录 拷贝构造函数一、为什么用拷贝构造二、拷贝构造函数1、概念2、特征1. 拷贝构造函数是构造函数的一个重载形式。2. 拷贝构造函数的参数3. 若未显式定义&#xff0c;编译器会生成默认的拷贝构造函数。4. 拷贝构造函数典型调用场景 拷贝构造函数 一、为什么用拷贝构造 日期…

赛宁网安多领域创新成果亮相第五届“纵横”论坛

10月27日&#xff0c;第五届“纵横”网络空间安全创新论坛在安徽合肥举办&#xff0c;来自中央国家机关、地方政府、军队有关单位、高校、科研院所和部分高新技术企业的领导、专家和代表500余人参加。 本届论坛由军事科学院和国防科技大学等单位共同主办&#xff0c;国防科技大…

【原创】java+swing+mysql个人理财管理系统设计与实现

摘要&#xff1a; 个人理财管理系统是一款帮助用户有效管理个人财务的软件&#xff0c;本文将详细介绍该系统的设计过程&#xff0c;包括功能模块、数据库设计、界面设计等&#xff0c;系统采用javaswingmysql技术组合。 功能分析&#xff1a; 系统主要提供给管理员、用户使…

金蝶云星空创建自动下推并保存公共服务

文章目录 金蝶云星空创建自动下推并保存公共服务创建公共方法按单下推数据按明细行下推数据调用下推操作 调用公共方法 金蝶云星空创建自动下推并保存公共服务 创建公共方法 按单下推数据 /// <summary>/// 获取单据转换数据包/// </summary>public DynamicObjec…

M3重磅来袭 苹果多款新品上架

10月31日早上8点&#xff0c;苹果举行了新品发布会&#xff0c;正式发布了M3、M3 Pro、 M3 Max芯片&#xff0c;以及基于新款芯片打造的14英寸和16英寸MacBook Pro、新款iMac。 我们现在花一分钟&#xff0c;简单了解一下这次的新品。 M3、M3 Pro、M3 Max M3系列芯片就是M2系…

关于测试组件junit切换testng的示例以及切换方式分享

文章目录 概要首先看看junit和testng的区别实践篇摸拟业务逻辑代码简单对象数据层摸拟类业务逻辑层摸拟类后台任务摸拟类 基于springmockjunit基于springmocktestng 示例的差异点junit与testng的主要变动不大,有以下几个点需要注意注解部分在before,after中testng多出按配置执行…

Spring 事务不生效的几种场景

Spring 事务不生效的几种场景 详细内容参考以下链接&#xff0c;这个链接是原文&#xff1a; spring 事务不生效的15中场景 非原创。 以下内容只是为了学习&#xff0c;加深印象&#xff0c;仅作为个人学习笔记&#xff0c; 请支持原创&#xff0c;内容请点击 spring 事务不生效…

链动2+1模式:白酒产品的营销新策略

链动21模式是一种创新的营销模式&#xff0c;结合白酒产品更能发挥其优势。该模式通过独特的身份晋升和奖励机制&#xff0c;快速建立销售渠道&#xff0c;提高用户粘性。 一、核心机制 身份晋升机制&#xff1a;用户购买指定499白酒产品后成为代理&#xff0c;再邀请两位用户…

新风机如何联动?

数据中心的运行会产生大量的热量&#xff0c;因为其中包含了大量的服务器、存储设备以及网络设备等&#xff0c;它们需要消耗大量的电力来进行计算和数据处理。为了保证这些设备运行的稳定性和性能&#xff0c;数据中心必须维持适宜的温度和湿度。 新风系统可以在数据中心中起到…

小米澎湃OS发布,雷军小米的“统一”大棋局

千呼万唤始出来。2023年10月26日&#xff0c;小米澎湃OS终于揭开面纱。 雷军在主题为“跨越时刻”的发布会上&#xff0c;正式发布了小米澎湃OS。面对这款历时七年打造的全新操作系统&#xff0c;雷军难掩兴奋&#xff0c;他感慨道&#xff1a;“我心澎湃”。 小米新操作系统取…

微信小程序项目案例之导游证考试刷题小程序

前言 很多计算机专业的同学在做毕设选题时不知道该如何选题&#xff0c;有的同学是已经选择了要开发一款小程序&#xff0c;但是又不知道开发哪类小程序。本篇将为大家介绍一个小程序的开发方向&#xff0c;考试刷题类小程序是目前比较火的小程序项目之一&#xff0c;在小程序…

CB2-2CARD的openSUSE远程SSH登录提示优化

CB2-2CARD的openSUSE远程SSH登录提示优化 1. 源由2. 优化内容2.1 去掉Password/banner前后的prompts提示语句2.2 增加logo登录界面2.3 增加系统运行情况简单汇报2.4 增加banner 3. 优化效果 1. 源由 之前运行的CB2-2CARD的openSUSE安装&NAS环境配置服务器已经运行也有段时…

(c语言进阶)字符串函数、字符分类函数和字符转换函数

一.求字符串长度 1.strlen() (1)基本概念 头文件&#xff1a;<string.h> (2)易错点&#xff1a;strlen()的返回值为无符号整形 #include<stdio.h> #include<string.h> int main() {const char* str1 "abcdef";const char* str2 "bbb&q…

审核 Microsoft SQL Server 日志

手动审核数据库活动是一项艰巨的任务&#xff0c;有效完成审计的最佳方法是使用简化和自动化数据库监控的综合解决方案&#xff0c;该解决方案还应使数据库管理员能够监控、跟踪和即时识别任何操作问题的根本原因&#xff0c;并实时检测对机密数据的未经授权的访问。 什么是 S…