原题链接:排序
解题思路:
折半插入排序:通过折半查找,找到插入元素在有序表中的插入位置,然后把该元素插入有序表中
①:建立一张空的顺序表
②:用折半查找法找到插入位置
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]);
}别忘点赞哦-.-
0.0分
8 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复