C语言:插入排序

ops/2024/10/18 20:39:26/

插入排序

  • 1.解释
  • 2.步骤
  • 3.举例分析
    • 示例
    • 结果
    • 分析

1.解释

插入排序是一种简单直观的算法>排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序)。

2.步骤

  1. 从第一个元素开始,该元素可以认为已经排序
  2. 取出下一个元素,在已经排序的元素序列中从后向前扫描
  3. 如果该元素(已排序)大于新元素,将该元素移到下一位置
  4. 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置
  5. 将新元素插入到该位置后
  6. 重复步骤2~5
    如果排序序列是链表结构,插入排序可以实现在O(1)空间复杂度内完成排序。

3.举例分析

示例

#include <stdio.h>
// 插入排序函数
void in(int arr[], int n) {int i, k, j;for (i = 1; i < n; i++) {k = arr[i];j = i - 1;// 将arr[0...i-1]中比k大的元素向后移动while (j >= 0 && arr[j] > k) {arr[j + 1] = arr[j];j = j - 1;}arr[j + 1] = k;}
}
// 用来打印数组的函数
void print(int arr[], int size) {int i;for (i = 0; i < size; i++)printf("%d ", arr[i]);printf("\n");
}
// 主函数来演示排序过程
int main() {int arr[] = {12, 11, 13, 5, 6};int n = sizeof(arr)/sizeof(arr[0]);in(arr, n);print(arr, n);return 0;
}

结果

在这里插入图片描述

分析

这段代码首先定义了一个in函数,它接受一个整数数组和数组的长度。在in函数中,通过一个for循环来遍历数组中的每个元素,将每个元素插入到已排序部分的正确位置。print函数则用于打印排序后的数组。
插入排序在小规模数据或者基本有序的数据面前,这是一个非常有效的算法>排序算法。在最好的情况下,即输入数组已经是排序好的。


http://www.ppmy.cn/ops/25299.html

相关文章

【C++】手撕list(list的模拟实现)

目录 01.节点 02.迭代器 迭代器运算符重载 03.list类 &#xff08;1&#xff09;构造与析构 &#xff08;2&#xff09;迭代器相关 &#xff08;3&#xff09;容量相关 &#xff08;4&#xff09;访问操作 &#xff08;5&#xff09;插入删除 我们在学习数据结构的时候…

程序员商业模式画布

首先&#xff0c;我们来关注价值主张。这个提议的核心理念是减轻那些认为学习是痛苦过程的人的困扰&#xff0c;给他们一点激励&#xff0c;好让他们能够持续、轻松地学习。 我们的目标是通过为学习过程增添乐趣&#xff0c;来缓解那些不太愿意学习的人的痛苦感&#xff0c;从…

一种基于YOLOv8改进的高精度红外小目标检测算法 (原创自研)

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文摘要&#xff1a;一种基于YOLOv8改进的高精度小目标检测算法&#xff0c; 在红外小目标检测任务中实现暴力涨点&#xff1b; &#x1f4a1;&#x1f4a1;&#x1f4a1;创新点&#xff1a; 1&#xff09;SPD-Conv特别是在处理低分…

Linux--MyMiniTry--Vim

首先下载好vim,我们可以按以下的方式进行光标的移动&#xff08;也可以回车进行换行&#xff09; &#xff08;--> 进入教程&#xff09; &#xff08;初始的时候没有文本&#xff0c;你怎么按都没有用&#xff09; &#xff08;我们要先按 i &#xff0c;进行插入文本才…

C语言实验-函数与模块化程序设计

一&#xff1a; 编写函数fun&#xff0c;其功能是&#xff1a;输入一个正整数&#xff0c;将其每一位上为偶数的数取出重新构成一个新数并输出。主函数负责输入输出&#xff0c;如输入87653142&#xff0c;则输出8642。&#xff08;main函数->fun函数&#xff09; #define _…

实验 AHT20模块驱动

1、项目说明 该项目使用单片机驱动AHT20&#xff0c;目前程序使用官网提供的源代码&#xff0c;但是不能直接拿来用&#xff0c;需进行部分修改。 2、源文件修改 2.1 原文件中关于AHT20_Clock_Init函数的初始化。 void AHT20_Clock_Init(void) {RCC_APB2PeriphClockCmd(C…

Python+Selenium基于PO模式的Web自动化测试框架

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、什么是Selenium&#xff1f; Selenium是一个基于浏览器的自动化测试工具&#xff0c;它提供…

技术解答 | ESP32 S2有虚拟U盘相关的例程吗?

最近在帮一个客户做ESP32-S2R2票务打印机项目的时候&#xff0c;对面工程师提出这样的问题&#xff0c;ESP32S2有虚拟U盘相关的例程吗&#xff1f; 针对这样的问题&#xff0c;启明云端工程师给出这样的回答&#xff1a; esp-idf可以参考这里面的示例&#xff1a; https://gi…