C语言---排序算法7---折半插入排序

文章目录

折半插入排序(Binary Insertion Sort)是插入排序的一种优化版本,通过二分查找确定插入位置,减少了比较次数,从而提升排序效率。

1. 算法步骤

1、初始状态:将数组分为已排序部分(初始为第一个元素)和未排序部分。

2、遍历未排序部分:

对当前元素 key,在已排序部分中使用二分查找确定插入位置 pos。

将 pos 之后的元素向后移动一位,腾出空间。

将 key 插入到 pos 位置。

3、重复:直到所有元素处理完毕。

2. 代码实现

以下代码通过二分查找寻找到需要插入的位置,在返回需要插入的位置后,移动数组。

c 复制代码
#include <stdio.h>

// 二分查找函数:在已排序数组arr[low..high]中找到key的插入位置
int binary_search(int arr[], int key, int low, int high) {
    while (low <= high) {
        int mid = low + (high - low) / 2;
        if (arr[mid] == key) {
            return mid; // 找到相等元素,返回其位置
        }
        if (arr[mid] < key) {
            low = mid + 1;
        } else {
            high = mid - 1;
        }
    }
    return low; // 未找到时返回第一个大于key的位置
}

// 折半插入排序函数
void binary_insertion_sort(int arr[], int n) {
    for (int i = 1; i < n; i++) {
        int key = arr[i];
        int pos = binary_search(arr, key, 0, i - 1); // 在已排序部分查找插入位置
        // 移动元素:从pos到i-1的元素向后移动一位
        for (int j = i - 1; j >= pos; j--) {
            arr[j + 1] = arr[j];
        }
        arr[pos] = key; // 插入key到正确位置
    }
}

int main() {
    int arr[] = {37, 23, 0, 17, 12, 72, 31};
    int n = sizeof(arr) / sizeof(arr[0]);
    
    printf("原始数组: ");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    
    binary_insertion_sort(arr, n);
    
    printf("排序后数组: ");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    
    return 0;
}

4. 优缺点

4.1、优点:

1、减少比较次数,对大规模数据比普通插入排序更快。

2、稳定且原地排序。

4.2、缺点:

1、移动次数未优化。

2、对随机数据效率不如更高级的排序(如快速排序、归并排序)。

推荐视频

数据结构合集 - 折半插入排序(算法过程, 效率分析, 稳定性分析)

相关推荐
为何创造硅基生物8 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
吃好睡好便好8 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅9 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
jolimark10 小时前
C语言自学攻略:小白入门三步走
c语言·编程入门·学习路线·实践项目·自学攻略
cen__y10 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
社交怪人11 小时前
【算平均分】信息学奥赛一本通C语言解法(题号2071)
c语言·开发语言
x_yeyue11 小时前
三角形数
笔记·算法·数论·组合数学
卢锡荣12 小时前
单芯通吃,盲插标杆 —— 乐得瑞 LDR6020,Type‑C 全场景互联 “智慧芯”
c语言·开发语言·计算机外设
念何架构之路12 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星12 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi