C# 插入排序

栏目总目录


概念

插入排序(Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,找到排序位置后,需要将已排序元素逐步向后挪位,为最新元素提供插入空间。

原理

插入排序的基本思想是:将数组分为已排序和未排序两部分,初始时,已排序部分只包含一个元素,其余均为未排序部分。然后,依次从未排序部分取出元素,在已排序部分找到合适的位置插入。重复此过程,直到所有元素均排序完毕。

好处与不足

好处

  1. 稳定性:插入排序是稳定的排序算法,即相等元素的相对顺序在排序前后保持不变。
  2. 适应性:对于小规模数据或基本有序的数据,插入排序的效率很高。
  3. 简单直观:算法逻辑清晰,易于理解和实现。

不足

  1. 效率低:在最坏情况下(即输入数据完全逆序),插入排序的时间复杂度为O(n^2),对于大规模数据排序效率较低。
  2. 数据移动:在插入过程中,可能需要移动大量元素,这在某些情况下(如链表排序)可能不是问题,但在数组中可能会成为性能瓶颈。

应用场景

插入排序适用于数据量不大或基本有序的情况。在数据量较小时,其简单性和稳定性使其成为不错的选择。此外,对于链表等数据结构,由于插入操作的高效性,插入排序也是一种常用的排序方法。

示例代码

基本实现

public void InsertionSort(int[] arr)
{int n = arr.Length;for (int i = 1; i < n; i++){int key = arr[i];int j = i - 1;/* 将arr[i]插入到arr[0...i-1]已排序的序列中 */while (j >= 0 && arr[j] > key){arr[j + 1] = arr[j];j = j - 1;}arr[j + 1] = key;}
}

泛型实现

为了增加代码的复用性,我们可以使用泛型来实现插入排序,使其能够排序任何实现了IComparable<T>接口的类型。

public void InsertionSort<T>(IList<T> list) where T : IComparable<T>
{int n = list.Count;for (int i = 1; i < n; i++){T key = list[i];int j = i - 1;/* 将list[i]插入到list[0...i-1]已排序的序列中 */while (j >= 0 && list[j].CompareTo(key) > 0){list[j + 1] = list[j];j = j - 1;}list[j + 1] = key;}
}

总结

插入排序是一种简单直观的排序算法,通过构建有序序列并在其中插入新元素来逐步完成排序。虽然其时间复杂度在最坏情况下为O(n^2),但在数据量较小或数据基本有序时,插入排序的效率很高。此外,插入排序的稳定性使其在某些需要保持元素相对顺序的场合下成为首选。通过理解插入排序的原理和特性,我们可以更好地选择和使用适合特定场景的排序算法。

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

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

相关文章

apache2和httpd web服务器

apache2和httpd web服务器 apache2和httpd web服务器是啥apache是软件基金会apache2是一个web服务httpd和apache2是同一个东西&#xff0c;但是不同linux发行版中叫法不一样。就是同一个东西&#xff0c;但是看上去有一些不一样。 apache2和httpd web服务器是啥 apache是软件基…

Scikit-learn内置的数据集

数据集是我们学习和研究机器学习不可或缺的基础&#xff0c;Scikit-learn库内置了丰富的数据集资源&#xff0c;非常适合初学者用来练习和验证机器学习算法的效果。 一、鸢尾花数据集 鸢尾花数据集&#xff08;Iris Dataset&#xff09;是机器学习领域中最著名的数据集之一&am…

在occluded Person Re-ID中,选择clip还是ViT作为backbone?

在遮挡行人再识别&#xff08;Occluded Person Re-Identification, Occluded Person Re-ID&#xff09;任务中&#xff0c;使用CLIP&#xff08;Contrastive Language-Image Pre-Training&#xff09;作为backbone和使用Vision Transformer&#xff08;ViT&#xff09;作为back…

【每日一篇】使用图神经网络进行交通速度预测的上下文感知知识图谱框架【为了自己方便读论文】

Context-aware knowledge graph framework for traffic speed forecasting using graph neural network 论文链接&#xff1a; https://arxiv.org/abs/2407.17703 翻译&#xff1a; 摘要 人类流动在空间和时间上受到城市环境的密切影响&#xff0c;构成了理解交通系统的重…

C语言 合并两个链表并按学号升序排列

已有a,b两个链表,每个链表中的结点包括学号、成绩。要求把两个链表合并,按学号升序排列。 #include <stdio.h> #include <stdlib.h>typedef struct Node {long num;float score;struct Node* next; } Node;Node* creat() {Node *head = NULL, *p1, *p2;p1 = p2 = …

MarkTool之UDP

UDP客户端&#xff0c;主要作用是与UDP服务端连接进行数据通讯 1、连接参数有4个&#xff0c;绑定IP和Port&#xff0c;服务端IP和Port 2、接收数据和发送数据的参数设置&#xff0c;有16进制&#xff0c;有字符&#xff0c;有原始数据&#xff0c;都可进行选择 3、定时发送&a…

理解常见开源协议的区别

本文将介绍几种常见的开源许可证&#xff0c;包括GPL、LGPL、MIT、Apache、BSD 和 木兰协议&#xff08;Mulan PSL&#xff09;&#xff0c;并详细解释它们的区别。 1. GPL (GNU General Public License) GPL 是最著名和最常用的开源许可证之一&#xff0c;由自由软件基金会 …

module federation模块联邦与微前端

module federation是什么 webpack5新增了module federation&#xff0c;module federation的作用&#xff0c;将每个构建(build)作为容器(这是一个概念)&#xff0c;构建后的资源可以正常部署&#xff0c;同时还具备在运行时对外暴露其中的模块&#xff0c;这就意味着多个构建…

泰安网站建设有几大特点

泰安网站建设的特点可以分为以下几个方面&#xff1a; 一、突出地域特色。泰安是山东省的一个地级市&#xff0c;具有悠久的历史和深厚的文化底蕴。在网站建设过程中&#xff0c;泰安的特色文化和旅游资源应得到充分的展示。可以通过优美的图片、详细的介绍和生动的文字&#x…

【Python 基础】字典和结构化数据 -1

字典和结构化数据 在本文中,我将介绍字典数据类型,它提供了一种灵活的访问和组织数据的方式。然后,结合字典与关于列表的知识,你将学习如何创建一个数据结构,对井字棋盘建模。 字典数据类型 像列表一样,“字典”是许多值的集合。但不像列表的下标,字典的索引可以使用…

科普文:11个编程原则助你写出优雅代码

糟糕的代码形式可以千千万&#xff0c;优雅且高质量的代码却是极其的相通&#xff0c;如何写出让人信服的高质量代码&#xff1f;编程是一个看似简单&#xff0c;但是还是有很大学问&#xff0c;特别是编写出高质量的优雅代码&#xff0c;最后我们再总结下本文总结的 11种原则&…

开源消息队列比较

目录 1. Apache Kafka 1.1安装步骤 1.1.1使用Docker安装 1.1.1手动安装 1.2 C#使用示例代码 1.2.1 安装Confluent.Kafka 1.2.2生产者代码示例 1.2.3消费者代码示例 1.3特点 1.4使用场景 2. RabbitMQ 2.1安装步骤 2.1.1使用Docker安装 2.1.2手动安装 2.2 C#使用示…

【STM32】SysTick定时器

SysTick定时器 前言一、介绍最大计时时间 固件库函数体现用途 总结 前言 参考一下猫咪博主的文章&#xff0c;作为补充学习⇨【STM32】Systick滴答定时器 当然我主要还是跟着金善愚老师学的&#xff0c;我觉得他真的有种高中班主任的亲切感。那个1812的名号往那里一放&#x…

ChanCMS是一款基于Express和MySQL研发的高质量实用型CMS管理系统

系统介绍&#xff1a;ChanCMS 基于expressmysql的一款轻量级高质量cms管理系统 ChanCMS是一款基于Express和MySQL研发的高质量实用型CMS管理系统。它具备多种类型网站开发&#xff0c;如公司&#xff0c;企业&#xff0c;学校&#xff0c;政府&#xff0c;图片&#xff0c;下载…

【vluhub】elasticsearch漏洞

Elasticsearch介绍 是Apache旗下的一个开源的、分布式、RESTful的搜索和分析引擎&#xff0c;适用于java语言项目 默认端口9200 kali中搭建ElasticHD, 即可未授权绕过ES可视化界面 直通车 https://github.com/360EntSecGroup-Skylar/ElasticHD/releases/download/1.4/elas…

吃肉的刷题记录2-贪心

文章目录 贪心贪心算法的特点&#xff1a;贪心算法的应用场景&#xff1a;贪心算法的设计步骤&#xff1a;实现注意事项&#xff1a; 例题: leetcode.322.零钱兑换例题: leetcode 5.最长回文字符串 贪心 贪心算法是一种在每一步选择中都采取在当前状态下最好或最优&#xff08…

Csrf复习(pikachu靶场和防御手段)

CSRF漏洞简介 CSRF又称跨站请求伪造&#xff0c;是指攻击者在用户登录的状态下&#xff08;浏览器保存了用户的cookie&#xff09;通过伪造恶意url诱导用户点击&#xff0c;借助用户的cookie网站权限&#xff08;冒充用户身份来进行非法操作&#xff0c;对于服务器来说是合法的…

视觉SLAM第二讲

SLAM分为定位和建图两个问题。 定位问题 定位问题是通过传感器观测数据直接或间接求解位置和姿态。 通常可以分为两类&#xff1a;基于已知地图的定位和基于未知地图的定位。 基于已知地图的定位 利用预先构建的地图&#xff0c;结合传感器数据进行全局定位。SLAM中的全局…

如何利用开源Bug管理系统提高团队效率

国内外主流的10款开源bug管理系统对比&#xff1a;PingCode、Worktile、Trac、WebIssues、MantisBT、Bugzilla 、Fossil、The Bug Genie、TestLink 、OpenProject。 在软件开发的复杂世界中&#xff0c;Bug管理可能是一个令人头疼的问题&#xff0c;尤其是当工具不足以捕捉和解…

这才是做项目的正确打开方式

基于大数据的推荐机制&#xff0c;对于没有接触到信息的人而言&#xff0c;会认为获取行业外的信息会很困难&#xff0c;对于已经接触到信息的人而言&#xff0c;又会出现选择困难症。当系统对你锁定标签后&#xff0c;就会频繁的给你推荐跟标签对应的信息&#xff0c;信息一多…