写出实现折半插入排序的算法或程序代码。

写出实现折半插入排序的算法或程序代码。


参考答案和解析
//算法8.2 折半插入排序#include using namespace std;#define MAXSIZE 20 //顺序表的最大长度typedef struct{int key;char *otherinfo;}ElemType;//顺序表的存储结构 typedef struct{ ElemType *r; //存储空间的基地址 int length; //顺序表长度}SqList;//顺序表void BInsertSort(SqList &L){//对顺序表L做折半插入排序int i,j,low,high,m;for(i=2;i{L.r[0]=L.r[i]; //将待插入的记录暂存到监视哨中low=1; high=i-1; //置查找区间初值while(low{//在r[low..high]中折半查找插入的位置m=(low+high)/2; //折半if(L.r[0].key//插入点在前一子表else low=m+1; //插入点在后一子表}//whilefor(j=i-1;j>=high+1;--j) L.r[j+1]=L.r[j];//记录后移L.r[high+1]=L.r[0];//将r[0]即原r[i],插入到正确位置 }//for}//BInsertSortvoid Create_Sq(SqList &L){int i,n;coutcin>>n;//输入个数coutwhile(n>MAXSIZE){coutcin>>n;}for(i=1;i{cin>>L.r[i].key;L.length++;}}void show(SqList L){int i;for(i=1;icout}void main(){SqList L;L.r=new ElemType[MAXSIZE+1];L.length=0;Create_Sq(L);BInsertSort(L);coutshow(L);}

相关考题:

下列排序方法中,________是稳定的排序方法。 A、简单选择排序B、起泡排序C、快速排序D、直接插入排序E、折半插入排序

下列方法中,________是稳定的排序方法。 A、折半插入排序B、希尔排序C、快速排序D、堆排序

可以将排序算法分为:插入排序、()、选择排序、()、分配排序。

在程序设计中,所谓“实现算法”即是指写出源程序。()

试写出折半查找的递归算法。

插入排序方法可分为() A、直接插入排序B、折半插入排序C、选择插入排序D、希尔排序

下列方法中,()是稳定的排序方法。 A.堆排序B.希尔排序C.快速排序D.折半插入排序

5 写出下列算法的时间复杂度。(1)冒泡排序;(2)选择排序;(3)插入排序;(4)快速排序;(5)堆排序;(6)归并排序;

下列不属于内部排序的算法是()。A.归并排序B.拓扑排序C.树型排序D.折半插入排序

与直接插入排序法比较,折半插入排序法减少了排序过程中的()。A、排序总的趟数B、元素的移动次数C、元素之间的比较次数D、使用的辅助空间的数量

与顺序查找算法相比,折半查找算法的时间复杂性有多大程度的降低?它是如何提高算法的效率的?

简述二分检索(折半查找)算法的基本过程。

数据结构与算法里,以下算法时间复杂度是O(n*n)的是()。A、冒泡排序B、直接插入排序C、折半查找D、希尔排序

用贪心算法设计0-1背包问题。要求:说明所使用的算法策略;写出算法实现的主要步骤;分析算法的时间。

排序算法中,从尚未排序序列中依次取出元素与已排序序列(初始为空)中的元素进行比较(要求比较次数尽量少),然后将其放入已排序序列的正确位置的方法是()A、折半插入排序B、直接插入排序C、归并排序D、选择排序

下面的排序算法中,不稳定的是()A、起泡排序B、折半插入排序C、简单选择排序D、希尔排序E、基数排序F、堆排序

稳定的排序方法是()A、直接插入排序和快速排序B、折半插入排序和起泡排序C、简单选择排序和四路归并排序D、树形选择排序和shell排序

数据结构与算法里,直接插入排序必须需要使用return语句才能实现。

数据结构与算法里,不是插入排序的有()。A、直接插入排序B、希尔排序C、冒泡排序D、快速排序

判断题数据结构与算法里,直接插入排序必须需要使用return语句才能实现。A对B错

单选题排序算法中,从尚未排序序列中依次取出元素与已排序序列(初始为空)中的元素进行比较(要求比较次数尽量少),然后将其放入已排序序列的正确位置的方法是()A折半插入排序B直接插入排序C归并排序D选择排序

问答题用贪心算法设计0-1背包问题。要求:说明所使用的算法策略;写出算法实现的主要步骤;分析算法的时间。

单选题下面的排序算法中,不稳定的是( )。A起泡排序、折半插入排序、堆排序B折半插入排序、简单选择排序、堆排序C简单选择排序、希尔排序、堆排序D基数排序、堆排序、起泡排序。

单选题稳定的排序方法是()A直接插入排序和快速排序B折半插入排序和起泡排序C简单选择排序和四路归并排序D树形选择排序和shell排序

多选题下面的排序算法中,不稳定的是()A起泡排序B折半插入排序C简单选择排序D希尔排序E基数排序F堆排序

单选题与直接插入排序法比较,折半插入排序法减少了排序过程中的()。A排序总的趟数B元素的移动次数C元素之间的比较次数D使用的辅助空间的数量

填空题完成下列折半插入排序算法。 Void binasort(struct node r[MAXSIZE],int n) {for(i=2;i else low=mid+1 ; } for(j=i-1;j=low;j- -)r[j+1]=r[j] ; r[low]=() ; } }

多选题数据结构与算法里,以下算法时间复杂度是O(n*n)的是()。A冒泡排序B直接插入排序C折半查找D希尔排序