6-2 编写函数实现直接插入排序 分数 30 作者 YJ 单位 西南石油大学 编写函数实现直接插入排序。输入若干正整数,以0结束,采用直接插入排序将这些整数按照从大到小的顺序排序。 函数接口定义: void InsertSort(SqList &L); 其中 L 是待排序的关键字,采用顺序表存储。 裁判测试程序样例: #include <iostream> using namespace std; #define MAXSIZE 20 //顺序表的最大长度 typedef int ElemType; //顺序表的存储结构 typedef struct { ElemType *r;//存储空间的基地址 int length; //顺序表长度 }SqList;//顺序表类型 void InsertSort(SqList &L); void Create_Sq(SqList &L) { int i,n; cin>>n; i=1; while(n>0) { L.r[i]=n; cin>>n; i++; } L.length=i-1; } void show(SqList L) { int i; for(i=1;i<=L.length;i++) cout<<L.r[i]<<" "; } int main() { SqList L; L.r=new ElemType[MAXSIZE+1]; L.length=0; Create_Sq(L); InsertSort(L); show(L); return 0; } /* 请在这里填写答案 */ 输入样例: 5 9 1 3 0 输出样例: 在这里给出相应的输出。例如: 9 5 3 1

时间: 2024-04-02 22:35:05 浏览: 13
题目描述 编写函数实现直接插入排序。输入若干正整数,以0结束,采用直接插入排序将这些整数按照从大到小的顺序排序。 函数接口定义: void InsertSort(SqList &L); 其中 L 是待排序的关键字,采用顺序表存储。 样例 输入样例: 5 9 1 3 0 输出样例: 9 5 3 1 算法思路 直接插入排序的基本思想是将一个记录插入到已排好序的有序表中,从而得到一个新的、记录数增1的有序表。 算法步骤: 1、将第一个元素看做已经有序,从第二个元素开始,每次将一个待排序的元素,插入到前面已经排好序的数列中。直到所有元素都被插入到前面有序的数列中。 2、插入操作的实现:从后向前查找插入位置,找到插入位置后,将该位置后面的所有元素向后移动一位,再将该元素插入到该位置。 C++ 代码
相关问题

7-4 使用函数实现字符串复制 分数 10 作者 王秀 单位 福州大学 输入一个正整数 re

要实现字符串复制的函数,首先需要编写一个函数,接受一个字符串和一个正整数re作为参数,并返回复制后的字符串。 ```python def copy_string(s, re): return s * re ``` 这个函数中,s代表输入的字符串,re代表输入的正整数。函数使用了字符串乘法操作符,将字符串s复制re次,然后返回复制后的字符串。 接下来,我们可以调用这个函数来实现字符串复制。例如,如果输入的字符串是"abc",正整数re是3,那么调用函数可以得到复制后的字符串"abcabcabc"。 ```python s = "abc" re = 3 result = copy_string(s, re) print(result) # 输出为"abcabcabc" ``` 通过调用这个函数,我们可以实现将输入的字符串复制指定次数的功能。这样,无论输入的字符串是什么,我们都可以通过这个函数来实现字符串复制的操作。

r6-2 最大值函数重载 分数 10 作者 杨军 单位 四川师范大学 编写重载函数mymax可

重载函数是指同一个函数名可以在不同的参数类型下进行定义和使用。在一个程序中,如果需要对不同类型的数据进行比较,就可以使用函数重载来定义不同参数类型的比较函数。 在解决r6-2题目中的最大值函数重载问题时,我们可以根据题目要求,实现一个可以比较分数大小的重载函数mymax。 首先,我们需要定义一个结构体来表示分数,该结构体包含两个整型的成员变量,分别表示分子和分母。然后,重载函数mymax,使用该结构体作为参数类型。 mymax的实现思路如下: 1. 首先,比较两个分数的分子值的大小,如果分子值不相等,则分子大的分数大。 2. 如果分子值相等,那么比较两个分数的分母值的大小,分母小的分数大。 3. 如果分子和分母的值都相等,那么两个分数相等。 下面是mymax的具体实现: ``` struct Fraction{ int numerator; int denominator; }; Fraction mymax(Fraction a, Fraction b){ if(a.numerator != b.numerator){ return a.numerator > b.numerator ? a : b; } else if(a.denominator != b.denominator){ return a.denominator < b.denominator ? a : b; } else{ return a; //或者返回b,因为两个分数相等 } } ``` 通过以上的实现,我们可以在程序中调用mymax函数来比较两个分数的大小,根据返回值即可得到最大的分数。 以上就是如何用300字回答r6-2题目中的最大值函数重载问题的方法。

相关推荐

最新推荐

recommend-type

python2练习题——编写函数,输入数字,判断是否是素数

定义 素数又称质数。...(6)若n为大于或等于2的正整数,在n到 之间至少有一个质数。 (7)若质数p为不超过n( )的最大质数,则 。 (8)所有大于10的质数中,个位数只有1,3,7,9 素数密度公式 根据
recommend-type

Python入门程序 函数应用(判断素数、递归求n的阶乘、x的n次方、最大最小值、插入排序法)

Python入门程序 函数应用(判断素数、递归求n的阶乘、x的n次方、最大最小值、插入排序法) 1.判断素数 #编写函数,判断一个数是否是素数。 def isprime(n): if n==1: return False for i in range(2, n): if n ...
recommend-type

C++实现八个常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序等

本文实现了八个常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序 、快速排序、归并排序、堆排序和LST基数排序 首先是算法实现文件Sort.h,代码如下: /* * 实现了八个常用的排序算法:插入排序、冒泡排序...
recommend-type

广州大学 数据结构实验报告 实验四 查找和排序算法实现

实验四 查找和排序算法...用随机函数生成16个2位正整数(10~99),实现插入排序、选择排序、冒泡排序、双向冒泡、快速排序、二路归并排序等多种排序算法,输出排序中间过程、统计关键字的比较次数和记录的移动次数。
recommend-type

C语言模拟实现atoi函数的实例详解

主要介绍了C语言模拟实现atoi函数的实例详解的相关资料,atoi函数,主要功能是将一个字符串转变为整数,这里就实现这样的函数,需要的朋友可以参考下
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柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

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