经典算法之直接插入排序

经典算法之直接插入排序

活动地址:CSDN21天学习挑战赛

前言

作者是一个基础小白,现就读于天津理工大学通信工程,希望通过博客的方式记录我自己的学习笔记以及学习收获,并且希望能够与大家一同分享,一同交流。

**再长的路,一步一步也能走完,再短的路,不迈开双脚也无法到达.

一、插入排序

1.插入排序的介绍

插入排序的基本思路是每次插入一个元素,每一趟完成对一个待排元素的放置,直到全部插入完成。

2.直接插入排序

直接插入排序是一种最简单的排序方式,其基本操作是将一条记录插入到已排好的有序列表中,从而得到一个新的,记录数量增1的有序表。

请添加图片描述

  • 输入

n个数的序列,通常直接存放在数组之中,可能是任何顺序。

  • 输出

输入序列的一个新排列,满足从大到小的顺序·。

  • 算法说明

每次从原有数据中取出一个数,插入到之前已经排好的序列中,直到所有的数全部取完,那么新的有序排列就已经完成。

  • 算法流程

对于计算机来说,我们要告诉它如何实现比较大小,以及确定位置。

1.第一个元素直接放在第一个位置。
2.第二个元素与第一个元素比较,若比第一个元素答,则放在第一个元素后面,若比第一个元素小,则放在第一个元素前面。
3.第三个元素顺次从后向前比较,如果更小,将已排好的元素向后串位,直到找到合适的位置插入。
4.剩余其他元素顺次从后向前比较,持续第3步。
5.如果是待排元素是排好元素中最大的,只需比较一次,然后追加到已排好序列的后面。

3.伪代码

for a=2 to A.length;
key=A[a];
i=a-1;
while(i>0&&A[i]>key);
A[i+1]=A[i];
i=i-1;
A[i+1]=key;

初始计数器为2,代表第一个元素默认排好,从第二个元素开始操作,直到最后一个元素。每次用key记录新操作的元素,i的初始值代表当前操作元素的第一个元素,也就是第一个要与之比较的元素。
while循环为内层循环,作用是在已经排好的元素找到合适的位置,来将key值插入。
如果进入到循环体中执行,代表key值相对较小,还要向前寻找,同时,与之比对的元素要向后串位,因为此时可以确定,key一定在这个元素的前面,在进入下一次循环时,使用再前面一位的元素进行比较。
for循环的最后一行是将key插入到对应的位置,外层循环结束(每次循环插入一个数)。

二、算法实现

  • 输入数据(input):11,34,20,10,12,35,41,32,43,14

C++源代码

#include<iostream>
using namespace std;
void sort(int a[], int n);
void printarr(int a[], int n);
int main()
{
	int arr[10] = { 11,34,20,10,12,35,41,32,43,14 };
	int n = 10;
	printarr(arr, n);
	sort(arr, n);
	cout << endl;
	printarr(arr, n);
	return 0;
}
void sort(int a[], int n)
{
	int i,j,temp=0;
	for (i = 0; i < n; i++)
	{
		if (a[i] < a[i - 1])
		{
			temp = a[i];
			for (j = i - 1; j >= 0 && a[j] > temp; j--)
			{
				a[j + 1] = a[j];
			}
			a[j + 1] = temp;
		}
	}
	}
void printarr(int a[], int n)
{
	for (int i = 0; i < n; i++)
	{
		cout << a[i];
		cout << " ";
	}
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

神秘的老年人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值