浅谈2路插入排序算法及其简单实现

 更新时间:2015年08月12日 11:32:40   作者:zinss26914  
这篇文章主要介绍了浅谈2路插入排序算法及其简单实现,虽算不上是常用的排序方法,但在数据库等方面依然有用上的机会,需要的朋友可以参考下

2路插入排序算法是在直接插入排序算法的基础上增加了一个辅助数组,其目的是减少排序过程中的移动次数,需要增加n个记录的辅助空间。

难点可能在于对取余的考虑吧,可以把辅助数组看成一个环状空间,这样就能更好的理解辅助空间中最大值和最小值的位置了。

算法整体思想还是很简单的,直接贴出可运行代码,注释还是挺清楚的,大家直接看就ok了

C语言实现示例

  #include <stdio.h> 
  #include <stdlib.h> 
   
  void insert_sort(int *arr, int *temp, int n) 
  { 
    int i, first, final, k; 
   
    first = final = 0; 
    temp[0] = arr[0]; 
   
    for (i = 1; i < n; i ++) { 
      if (arr[i] < temp[first]) { // 待插入元素比最小的元素小 
        first = (first - 1 + n) % n; 
        temp[first] = arr[i]; 
      } else if (arr[i] > temp[final]) { // 待插入元素比最大元素大 
        final = (final + 1 + n) % n; 
        temp[final] = arr[i]; 
      } else { // 插入元素比最小大,比最大小 
        k = (final + 1 + n) % n; 
        while (temp[((k - 1) + n) % n] > arr[i]) { 
          temp[(k + n) % n] =temp[(k - 1 + n) % n]; 
          k = (k - 1 + n) % n; 
        } 
        temp[(k + n) % n] = arr[i]; 
        final = (fianl + 1 + n) % n; 
      } 
    } 
   
    // 将排序记录复制到原来的顺序表里 
    for (k = 0; k < n; k ++) { 
      arr[k] = temp[(first + k) % n]; 
    } 
  } 
   
  int main(void) 
  { 
    int i, n, *arr, *temp; 
   
    while (scanf("%d", &n) != EOF) { 
      arr = (int *)malloc(sizeof(arr) * n); 
      temp = (int *)malloc(sizeof(temp) * n); 
   
      for (i = 0; i < n; i ++) 
        scanf("%d", &arr[i]); 
   
      insert_sort(arr, temp, n); 
   
      for (i = 0; i < n; i ++) 
        printf("%d ", arr[i]); 
      printf("\n"); 
      free(arr); 
      free(temp); 
    } 
   
    return 0; 
  } 

  
同时附上C++写法:

#include<iostream>
using namespace std;
#define MAX 20
void PrintArray(int a[],int len){
 for(int i=0;i<len;i++)
 cout<<a[i]<<" ";
 cout<<endl;
}
void BinInsertSort(int a[],int len){
 int *d=(int *)malloc(len*sizeof(len));
 for(int i=0;i<len;i++)
 d[i]=0;
 int first=0,final=0;
 d[0]=a[0];
 for(int i=1;i<len;i++){
 if(a[i]<=d[first]){
  first=(first-1+len)%len;
  d[first]=a[i];
 }
 else if(a[i]>=d[final]){
  final=final+1;
  d[final]=a[i];
 }
 else{
  int j=final++;
  while(a[i]<d[j]){
  d[(j+1)%len]=d[j];
  j=(j-1+len)%len;
  }
  d[j+1]=a[i];
 }
 }
 cout<<"辅助数组中排序结果为:";
 PrintArray(d,len);
}
int main(){
 int a[MAX],len;
 cout<<"请输入待排序的元素个数:";
 cin>>len;
 cout<<"请输入待排序的元素:";
 for(int i=0;i<len;i++)
 cin>>a[i];
 BinInsertSort(a,len);
 system("pause");
 return 0;
}

相关文章

  • 示例详解C++语言中的命名空间 (namespace)

    示例详解C++语言中的命名空间 (namespace)

    C++名字空间是一种描述逻辑分组的机制,也就是说,如果有一些声明按照某种准则在逻辑上属于同一个模块,就可以将它们放在同一个名字空间,以表明这个事实,这篇文章主要给大家介绍了关于C++语言中命名空间 (namespace)的相关资料,需要的朋友可以参考下
    2021-08-08
  • C++ Qt开发之使用QUdpSocket实现UDP网络通信

    C++ Qt开发之使用QUdpSocket实现UDP网络通信

    Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,本文主要介绍如何运用QUdpSocket组件实现基于UDP的网络通信功能,需要的可以参考下
    2024-03-03
  • C++中rapidjson组装继续简化的方法

    C++中rapidjson组装继续简化的方法

    今天小编就为大家分享一篇关于C++中rapidjson组装继续简化的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-04-04
  • C++的get()函数与getline()函数使用详解

    C++的get()函数与getline()函数使用详解

    这篇文章主要介绍了C++的get()函数与getline()函数使用详解,是C++入门学习中的基础知识,需要的朋友可以参考下
    2015-09-09
  • 简要说明C语言中指针函数与函数指针的区别

    简要说明C语言中指针函数与函数指针的区别

    这篇文章主要介绍了C语言中指针函数与函数指针的区别,指针函数和函数指针是C语言入门学习中的基础知识,需要的朋友可以参考下
    2016-04-04
  • C语言MFC基础之计算器详解

    C语言MFC基础之计算器详解

    这篇文章主要为大家介绍了MFC实现简单的计算器,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-08-08
  • C语言字符函数、内存函数功能及实现代码

    C语言字符函数、内存函数功能及实现代码

    这篇文章主要介绍了C语言字符函数、内存函数 功能及实现,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • VC++ loadlibrary()加载三方dll失败, 返回错误码:126的解决方法

    VC++ loadlibrary()加载三方dll失败, 返回错误码:126的解决方法

    今天在编写VC++ loadlibrary()加载三方dll是总是失败,并且返回错误码:126,这里就为大家分享一下具体的解决方法
    2021-03-03
  • C语言中的malloc使用详解

    C语言中的malloc使用详解

    这篇文章主要介绍了C语言中的malloc的使用,包括用其动态申请二维数组等功能,需要的朋友可以参考下
    2015-08-08
  • C语言判断回文数的小例子

    C语言判断回文数的小例子

    这篇文章主要介绍了C语言判断回文数的小例子,有需要的朋友可以参考一下
    2014-01-01

最新评论