内部排序之插入排序(直接插入排序,二分插入排序,希尔插入排序)

本文详细介绍了三种插入排序算法:直接插入排序、二分插入排序和希尔排序。直接插入排序是最基本的插入排序,时间复杂度为O(n²)。二分插入排序通过折半查找提升插入效率,但总时间复杂度仍为O(n²)。希尔排序则是通过设定间隔序列逐步排序,其时间复杂度约为O(n的1.5次方)。三种排序算法的空间复杂度均为O(1),其中直接插入排序和二分插入排序是稳定的,而希尔排序是不稳定的。
摘要由CSDN通过智能技术生成

目录

  1. 直接插入排序简介及其代码
  2. 二分插入排序简介及其代码
  3. 希尔插入排序简介及其代码
  4. 插入排序总结

直接插入排序简介及其代码

简介:
这里写图片描述
直接插入排序过程:
这里写图片描述
代码块:

#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 100
typedef int KeyType;
typedef struct
{
    KeyType key;
    int data;
}RecType;
void InsertSort(RecType R[], int n)
{
    int i, j;
    RecType tmp;
    for (i = 1; i < n; i++)
    {
        tmp = R[i];
        j = i - 1;
        while (j >= 0 && tmp.key < R[j].key)
        {
            R[j + 1] = R[j];
            j--;
        }
        R[j+1] = tmp;

    }
}

int main(void)
{
    int i,n = 10;
    RecType R[MAXSIZE];
    KeyType a[] = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
    for (i = 0; i < n; i++)
    {
        R[i].k
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值