插入排序 算法

从第二个开始,从后面往前找,如果比其小,就交换,else 就终止

for i = 1 i <n i ++

for j = i j > 0 (到第二个) j--

if <

swap

下面给出源码

cpp 复制代码
//对插入排序来说,直接从第二个元素开始

template<typename T >
void InsertSort( T arr[], int n){
    for(int i = 1 ; i < n ; i++){

        //寻找【i应该插入的位置】,但是注意我们是从后面往前找所以j 要从后往前
        
        // for( int j = i  ; j > 0 ; j --)
        //     if(arr[j] < arr[j - 1] )
        //         swap(arr[j], arr[j-1]);
        //     else 
        //         break;
        
        for( int j = i  ; j > 0 && arr[j] < arr[j - 1]; j --)
                swap(arr[j], arr[j-1]);
            

       

    }


int main()
{
  int n = 100000;
    int *arr = SortTestHelper :: generateRandomArr(n, 0, n) ;
    int *arr2 = SortTestHelper :: copyIntArray(arr, n);
    // InsertSort(arr2, n);
    // SortTestHelper :: printarr(arr2, n);
    // selectionSort( arr, n );
    // SortTestHelper :: printarr(arr, n);
    SortTestHelper::test_sort("selection Sort", selectionSort, arr,n);
    SortTestHelper::test_sort("Insertion Sort", InsertSort, arr2,n);

    delete[] arr;
    delete[] arr2;

    return 0;

}

辅助函数 多了一个copy

给出完整代码

cpp 复制代码
       int* copyIntArray(int a[], int n){
        
        int* arr = new int[n];
        copy(a, a + n, arr);
        
        return arr;
       }
       
相关推荐
C_Liu_1 分钟前
14:C++:二叉搜索树
算法
CC-NX11 分钟前
32位汇编:实验9分支程序结构使用
汇编·算法·win32·分支结构
万岳科技系统开发17 分钟前
外卖小程序中的高并发处理:如何应对大流量订单的挑战
算法·小程序·开源
TL滕21 分钟前
从0开始学算法——第二天(时间、空间复杂度)
数据结构·笔记·学习·算法
旺仔老馒头.2 小时前
【数据结构与算法】手撕排序算法(二)
c语言·数据结构·算法·排序算法
好学且牛逼的马2 小时前
【Hot100 | 2 LeetCode49 字母异位词分组问题】
算法
2301_795167202 小时前
Rust 在内存安全方面的设计方案的核心思想是“共享不可变,可变不共享”
算法·安全·rust
努力努力再努力wz3 小时前
【Linux进阶系列】:线程(上)
java·linux·运维·服务器·数据结构·c++·redis
czhc11400756633 小时前
Java117 最长公共前缀
java·数据结构·算法
java 乐山3 小时前
蓝牙网关(备份)
linux·网络·算法