折半插入排序C语言实现

折半插入排序C语言实现_第1张图片

 折半插入排序的原理如上图

代码如下:

#include//折半插入排序 

void zhebaninsertsort(int a[],int n){
	int i,p;
	int temp;
	for(p=1;p=high+1;i--) {
	     a[i+1]=a[i];
		 }
	     a[high+1]=temp;
	     
	 }
}
 
int main(){
	int n;
	scanf("%d",&n);
	int a[n];
	int i;
	for(i=0;i

在写这个代码的过程中,由于我的粗心,把while循环里面的high=mid-1写成了high=low-1

错误代码如下:

#include//折半插入排序 

void zhebaninsertsort(int a[],int n){
	int i,p;
	int temp;
	for(p=1;p=high+1;i--) {
	     a[i+1]=a[i];
		 }
	     a[high+1]=temp;
	     
	 }
}
 
int main(){
	int n;
	scanf("%d",&n);
	int a[n];
	int i;
	for(i=0;i

测试结果时:

折半插入排序C语言实现_第2张图片

用这个错误代码测试了好几个数据都对了,可能是阴差阳错的对的,这个却错了还把我搞懵逼了

我又补充了输出每一步的排序结果来检查我的代码到底是哪一步错了

代码如下:

#include//折半插入排序 

void zhebaninsertsort(int a[],int n){
	int i,p;
	int temp;
	for(p=1;p=high+1;i--) {
	     a[i+1]=a[i];
		 }
	     a[high+1]=temp;
	     for(i=0;i

 折半插入排序C语言实现_第3张图片

 我又定位到错误的那一步,一步步去推导还是感觉没问题,后来看了半天才发现是mid敲成了low,但我的思想里我依然写的是mid。所以,写代码一定一定要细心再细心,一个单词的错误就可以导致很多的错误,然后我还根本发现不了。

你可能感兴趣的:(c语言)