插入排序(C语言)

server/2024/11/14 15:10:34/

直接插入排序的基本思想:把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。

一、步骤

1.给定一个乱序的数组,如

从第一个元素开始排序,当只有第一个元素4时,我们可以认为它是有序的。

2.然后取出下一个元素,在这里是第二个元素即5,将这个元素赋值变量tmp,然后进行插入

3.如果前一个元素大于tmp,则该元素向后移,重复上述步骤,直到找到小于tmp的位置

4.找到小于tmp元素的位置后,插入到该元素的后面,就完成了一次插入排序

图片演示:

重复上述步骤,直到排序结束。

二、代码

void InsertSort(int* arr, int n)  //n是数组的大小  n = sizeof(arr)/sizeof(int)
{for (int i = 0; i < n - 1; i++)  //i < n - 1而不是小于n是为了避免越界访问{int end = i; //到[0,end]是一个有序的数组int tmp = arr[end + 1];while (end >= 0){if (arr[end] > tmp){arr[end + 1] = arr[end];end--;}else{break;}} //出循环时,end指向的是小于tmp元素的位置。当end = -1时,代表tmp的值是在有序数组中最小的值arr[end + 1] = tmp;}
}


http://www.ppmy.cn/server/141642.html

相关文章

comfyUI官方笔记整理

官网教程笔记ComfyUI_examples 1.ComfyUI基础教程ComfyUI Basic Tutorial VN 从网上下载下来的模型ckpt和safetensors包含有3个不同的模型&#xff0c;CLIP&#xff0c;主模型还有VAEclip模型会和CLIPTextEncode进行连接&#xff0c;将文本编码为模型可以理解的向量形式。在S…

git之 revert和rebase

当我们想要回滚代码并保留之前的提交时 通过 git revert 需要回滚的提交单号" git rebase “目标分支" 如a分支开发&#xff0c;B是目标分支&#xff08;最终的远程上线分支) a 是基于B拉取的 当B有其他人提交之后 要将B的合入到a, 则需要在a 分支上执行 git reba…

微积分复习笔记 Calculus Volume 1 - 5.1 Approximating Areas

5.1 Approximating Areas - Calculus Volume 1 | OpenStax

C# 选择文件夹路径

通过C#代码&#xff0c;调出windows风格的文件夹选择框。提供界面来选择指定文件夹&#xff0c;并将文件夹完整路径以字符串形式返回。 示例&#xff1a; 代码&#xff1a; #region 选择指定文件夹 string folderPath ""; FolderBrowserDialog folderBrowserDialo…

jupyter notebook启动和单元格cell

【注意&#xff01;&#xff01;&#xff01;】 本章主要讲解数据分析、挖掘入门及进阶知识 - 通过多篇文章【文字案例】的形式系统化进行描述 数据分析专栏&#xff1a;https://blog.csdn.net/2201_75422674/category_12827743.html - 大家喜欢可以订阅一下&#xff0c;不收费…

如何选择适合小团队的项目管理工具?免费与开源软件推荐

目录 一、小团队项目管理工具的重要性 二、热门项目管理工具介绍 &#xff08;一&#xff09;禅道 &#xff08;二&#xff09;Trello &#xff08;三&#xff09;Asana &#xff08;四&#xff09;JIRA 三、免费项目管理软件推荐 &#xff08;一&#xff09;ES 管理器 …

Vue.js 高质量翻页功能的完整开发指南

文章目录 Vue.js 翻页组件的完整开发与优化指南前言分析分页需求与设计要点基础分页功能的实现分页逻辑 优化分页&#xff1a;封装为组件化设计组件化代码 提升用户体验与性能动态调整每页显示的条目数优化移动端与桌面端的展示高性能翻页策略&#xff1a;按需加载与懒加载提示…

RHCE的学习(16)(shell脚本编程)

第一章、shell入门基础 1.1 为什么学习和使用Shell编程 对于一个合格的系统管理员来说&#xff0c;学习和掌握Shell编程是非常重要的。通过编程&#xff0c;可以在很大程度上简化日常的维护工作&#xff0c;使得管理员从简单的重复劳动中解脱出来。 Shell程序的特点&#xff…