解题思路:

折半插入排序:通过折半查找,找到插入元素在有序表中的插入位置,然后把该元素插入有序表中


①:建立一张空的顺序表

②:用折半查找法找到插入位置


1):定义Low:指向有序表第一个元素

2):定义High:指向有序表最后一个元素

3):定义mid=(Low+High)/2:指向中间元素

4):设有序表为data[100],插入元素为x

5):如果x<data[mid],则High=mid-1

6):如果x>data[mid],则Low=mid+1

7):如果x==data[mid],则返回mid,作为插入位置

8):直到Low>High时结束循环内容:5)6)7)

9):若没找到则也要返回插入位置,此时返回插入位置Low


③:从有序表中,最后一个元素开始依次后移,直到插入位置结束

④:插入元素,同时有序表长度加1

⑤:输出结果

参考代码:

#include<stdio.h>

typedef struct List_{

 int data[100];
 int length;

}*list_,LIST;

void init_(list_ L);/*初始化顺序表*/
int half_search(list_ L,int x);
void insert_sort(list_ L,int x);
void out_put(list_ L);

int main()
{
  int x,n;/*输入的数,以及数的个数*/
  LIST L;

    while(scanf("%d",&n)!=EOF)
     {
           init_(&L);
           for(int i=0;i<n;i++)
             {
                scanf("%d",&x);
                insert_sort(&L,x);
             }
      out_put(&L);

     }
return 0;
}

/*----------------------------------------*/
void init_(list_ L)/*初始化顺序表*/
{
  L->length=0;
}
/*----------------------------------------*/
void insert_sort(list_ L,int x)
{

   int d=half_search(L,x);

     for(int i=L->length-1;i>=d;i--)
      {
         L->data[i+1]=L->data[i];
      }

       L->data[d]=x;
       L->length++;/*顺序表长度加一*/
return ;
}
/*----------------------------------------*/
int half_search(list_ L,int x)
{
    int Low=0, High=L->length-1, mid;/*让Low,High分别指向链表的左右两端*/
      while(Low<=High)
       {    mid=(Low+High)/2;
            if(x<L->data[mid])
              High=mid-1;
              else
              if(x>L->data[mid])
               Low=mid+1;
               else
               return mid;/*找到与它相同的直接返回*/
       }
       return Low;
}
/*----------------------------------------*/
void out_put(list_ L)
{
   for(int i=0;i<L->length-1;i++)
    printf("%d ",L->data[i]);

     printf("%d\n",L->data[L->length-1]);

}

别忘点赞哦-.-

点赞(6)
 

0.0分

8 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 2 条评论

ga 10月前 回复TA
@dotcpp0696638 大佬你来一个
dotcpp0696638 1年前 回复TA
又臭又长