递归插入排序的C程序

递归插入排序的c程序

插入排序是一种排序算法,它是一种基于就地比较的算法。

该算法的工作原理是将元素放置在已排序子数组中的位置,即元素之前的子数组是排序子数组。

算法

Step1 – 从 1 到 n-1 循环并执行 –

Step2 .1 – 选择位置 i 处的元素,array[i]。

Step2.2 – 将元素插入已排序的子数组 array[0] 中其位置到 arr[i]。

我们通过一个例子来理解一下算法

数组 = [34, 7, 12, 90, 51]

对于 i = 1,arr[1] = 7,放入子数组 arr[0] – arr[1] 中的位置。

[7, 34, 12, 90, 51]

对于 i = 2,arr[2] = 12,放入子数组 arr[0] – arr[2] 中的位置。

[7, 12, 34, 90, 51]

对于 i = 3,arr[3] = 90,将其放置在子数组 arr[0] – arr[3] 的位置。

[7, 12, 34, 90, 51]

对于 i = 4,arr[4] = 51,在子数组 arr[0] – arr[4] 中将其放置在正确的位置。

[7, 12, 34, 54, 90]

在这里,我们将看到递归插入排序的工作原理。它以相反的方式工作,即与当前迭代相比,我们将递归调用recursiveInsertionSort()函数来对n-1个元素的数组进行排序。然后在由函数返回的已排序数组中,我们将第n个元素插入到其在已排序数组中的位置。

递归插入排序的程序如下:

示例

 演示

#include void recursiveInsertionSort(int arr[], int n){   if (n = 0 && arr[j] > nth){      arr[j+1] = arr[j];      j--;   }   arr[j+1] = nth;}int main(){   int array[] = {34, 7, 12, 90, 51};   int n = sizeof(array)/sizeof(array[0]);   printf("Unsorted Array:t");      for (int i=0; i < n; i++)   printf("%d ",array[i]);      recursiveInsertionSort(array, n);   printf("

Sorted Array:t"); for (int i=0; i < n; i++) printf("%d ",array[i]); return 0;}

输出

Unsorted Array: 34 7 12 90 51Sorted Array: 7 12 34 51 90

以上就是递归插入排序的C程序的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1445508.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 22:34:31
下一篇 2025年12月13日 18:15:29

相关推荐

  • 六边形图案的C程序

    我们被给定一个整数’n’,任务是生成六边形图案并显示最终输出。 示例 Input-: n=5Output-: Input-: n = 4Output-: Approach we are using in the given program is as follows − In…

    2025年12月17日
    000
  • 如何使用C++中的插入排序算法

    使用C++中的插入排序算法实现数组排序 插入排序是一种简单但有效的排序算法,它将待排序的元素一个一个地插入已排序的列表中,最终得到一个有序的列表。本文将介绍如何使用C++编程语言实现插入排序算法,并给出具体的代码示例。 算法思想:插入排序的基本思想是将数组分为已排序区间和未排序区间。每次从未排序区间…

    2025年12月17日
    000
  • 一个使用C程序的谜题

    这里我们将看到一道 C 谜题。假设我们有两个数字 48 和 96。我们必须将第一个数字添加到第二个数字之后。所以最终的结果将是9648。但是我们不能使用任何逻辑、算术、字符串相关的操作,也不能使用任何预定义的函数。那么我们怎样才能做到这一点呢? 这很简单。我们可以通过在 C 中使用 Token Pa…

    2025年12月17日
    000
  • C程序实现欧几里得算法

    问题 实现欧几里得算法来查找两个整数的最大公约数 (GCD) 和最小公倍数 (LCM),并将结果与​​给定整数一起输出。 解决方案 实现欧几里得算法求两个整数的最大公约数 (GCD) 和最小公倍数 (LCM) 的解决方案如下 – 求 GCD 和 LCM 的逻辑如下 – if(…

    2025年12月17日
    000
  • 用动态链表存储汽车信息的C程序

    链接列表使用动态内存分配,即它们相应地增长和收缩。它是节点的集合。 节点有两部分,如下所示 – 数据链接 链表的类型 C 语言中链表的类型如下 – 单链表/单链表列表双链表循环单链表循环双链表 算法 参考下面给出的算法,使用动态链表存储汽车信息。 步骤 1 – 声…

    2025年12月17日
    000
  • C程序以PGM格式写入图像

    pgm 是便携式灰度地图。如果我们想在 c 中将二维数组存储为 png、jpeg 或任何其他图像格式的图像,则在写入文件之前,我们必须做大量工作以某种指定的格式对数据进行编码。 Netpbm 格式提供了一种简单且便携的解决方案。 Netpbm是一个开源的图形程序包,基本上使用在linux或Unix平…

    2025年12月17日
    000
  • Rabin-Karp算法的C程序用于模式搜索

    C 中的模式匹配– 我们必须查找一个字符串是否存在于另一个字符串中,例如,字符串“algorithm”存在于字符串“naive algorithm”中。如果是找到,然后显示它的位置(即它所在的位置)。我们倾向于创建一个接收 2 个字符数组的函数,如果匹配则返回位置否则返回-1。 Inpu…

    2025年12月17日
    000
  • 递归地打印给定的模式

    在这里,根据给定的问题模式,需要使用递归方法来显示。 递归函数是一个调用自身n次的函数。程序中可以有n个递归函数。递归函数的问题在于它们的复杂性。 算法 STARTStep 1 -> function int printpattern(int n) If n>0 Printpattern…

    2025年12月17日
    000
  • C++程序以给定值为参数,找到双曲正弦反函数的值

    双曲函数是使用双曲线而不是圆定义的,与普通三角函数相当。它从提供的弧度角返回双曲正弦函数中的比率参数。但要做相反的事,或者换句话说。如果我们想根据双曲正弦值计算角度,我们需要像双曲反正弦运算一样的反双曲三角运算。 本课程将演示如何使用 C++ 中的双曲反正弦 (asinh) 函数,使用双曲正弦值(以…

    2025年12月17日
    000
  • C程序使用结构体存储库存系统

    结构是不同数据类型变量的集合,以单一名称分组在一起。 结构的特征 C 语言中结构的特征编程语言如下 – 可以通过使用赋值将不同数据类型的所有结构元素的内容复制到其类型的另一个结构变量 为了处理复杂的数据类型,最好在另一个结构中创建结构,这称为嵌套结构。 可以将整个结构、结构的各个元素和结…

    2025年12月17日
    000
  • C程序打印“偶数”或“奇数”,不使用条件语句

    在本节中,我们将看到如何在不使用任何条件语句(如,>=,==)的情况下检查一个数是奇数还是偶数。 我们可以通过使用条件语句轻松地检查奇数还是偶数。我们可以将数字除以2,然后检查余数是否为0。如果为0,则是偶数。否则,我们可以将数字与1进行AND运算。如果答案为0,则是偶数,否则为奇数。 这里不…

    2025年12月17日
    000
  • C++程序,使用递归将二进制数转换为格雷码

    格雷码或反射二进制码是一种特殊类型的数字二进制表示形式,其中两个连续值仅在一位上不同。例如,1和2的二进制等价物是01和10,这里有两个位正在改变。但在格雷码中,1是01,2是11,只有一位在变化。在本文中,我们将了解如何使用 C++ 中的递归将给定的二进制数转换为其等效的格雷码。 将数字作为十进制…

    2025年12月17日
    000
  • 递归冒泡排序的C程序

    冒泡排序是最简单的排序算法之一,用于通过比较相邻元素对数据进行排序。所有元素都分阶段进行比较。第一阶段将最大值放在最后,第二阶段将第二大元素放在倒数第二个位置,依此类推,直到完整列表排序完毕。 冒泡排序算法 int arr[5]= { 5,4,2,1,3 }; int i, j ; 从索引 i=0 …

    2025年12月17日
    000
  • C++程序来检查一个字符是否为字母或非字母

    在解决一些逻辑编程问题时,使用字符串或字符有时非常有用。字符串是字符的集合,字符是 1 字节数据类型,用于保存 ASCII 值中的符号。符号可以是英文字母、数字或特殊字符。在本文中,我们将学习如何使用 C++ 检查一个字符是否是英文字母或字母表中的字母。 检查 isalpha() 函数 要检查数字是…

    2025年12月17日
    000
  • C程序乘以两个浮点数?

    Float是“浮点数”的缩写。按照定义,它是编译器内置的基本数据类型,用于定义具有浮动小数点的数值。浮点类型变量是可以保存实数的变量,例如4320.0、-3.33或0.01226。浮点数名称中的浮点部分指的是小数点可以“浮动”,即可以支持小数点前后可变数量的数字。 浮点数 类别 类型 最小大小 典型…

    2025年12月17日
    000
  • 寻找给定列表的中位数的C程序

    如果列表中的元素按顺序排列,则将列表中的元素分成两部分且两边元素数量相等的中间值称为中位数。 元素个数为奇数只有一个中间值;而;偶数个项目有两个中间值。 因此,偶数个项目的中位数被指定为两个中间值的平均值。 算法 请参考下面给出的算法来计算中位数。 步骤 1 – 将项目读入数组,同时保留…

    2025年12月17日
    000
  • 将以下内容翻译为中文:使用递归在C程序中将二进制转换为格雷码

    二进制数是只有两位 0 和 1 的数字。 格雷码是一种特殊类型的二进制数,其属性是代码的两个连续数字 em> 的差异不能超过一位。格雷码的这一特性使其在 K-map、纠错、通信等方面更加有用。 这使得二进制到格雷码的转换成为必要。那么,让我们看一下将二进制转换为格雷码的算法使用递归。 示例 让…

    2025年12月17日
    000
  • C程序中前n个偶数的平方和

    前n个偶数的平方和意味着,我们首先找到平方并将它们全部相加得到总和。 有两种方法可以找到前n个偶数的平方和 使用循环 我们可以使用循环从1到n迭代,每次增加1,找到平方并将其加到总和变量中− 例子 #include using namespace std;int main() { int sum =…

    2025年12月17日
    000
  • 活动选择问题的C程序

    活动选择问题是给定一组活动及其开始和结束时间的问题。我们需要找到一个人一次执行单个活动可以执行的所有活动。 此问题指定贪婪算法来选择下一个要执行的活动。我们先来了解一下贪心算法。 贪心算法是一种试图通过一步步寻找解来寻找问题解决方案的算法。为了选择下一步,该算法还选择了似乎最有希望的步骤,即与休息相…

    2025年12月17日
    000
  • 在C程序中,编译时错误和运行时错误之间的区别是什么?

    错误或异常是指由于代码执行中断而无法达到预期结果的情况。根据生成或识别错误的事件,我们可以将其分类为编译时错误和运行时错误。 以下是编译时错误和运行时错误之间的重要区别。 序号 关键 编译时错误 运行时错误 1参考编译时错误通常指与语法或语义相关的错误。另一方面,运行时错误指的是在运行时执行代码时遇…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信