C语言:在一个有序数组中插入一个整数,并保持有序性

#include
#include 
int main(){
    int a[11]={105,40,28,19,16,13,9,6,4,2};
    int x,i,j,k;
    printf("请输入一个整数:\n");
    scanf("%d",&x);
    if(a[0]<a[1]){          //原数组是升序排列
        if(x<a[0]){         //输入的x小于最小的a[0]
			for(j=9;j>=0;j--){  //其余元素依次后撤
				a[j+1]=a[j];
			}
			a[0]=x;
        }
        else if(x>a[9]){ //输入的x大于最大的a[9]
			a[10]=x;
        }
		else{
		for(i=0;i<10;i++){
			if(x>a[i] && x<a[i+1]){
				for(j=10;j>i+1;j--){  //注意j的范围,a[10]到a[i+1]依次后错
					a[j]=a[j-1];
				}
				a[j]=x;   //在for循环外
			}
		}
	}
}
    else {                   //原数组是降序排序
    	if(x>a[0]){         //输入的x大于最大的a[0]
			for(j=9;j>=0;j--){ //其余元素依次后撤
				a[j+1]=a[j];
			}
			a[0]=x;
        }
        else if(x<a[9]){ //输入的x小于最小的a[9]
			a[10]=x;
        }
        else
			{
			for(i=0;i<10;i++){
			if(x<a[i] && x>a[i+1]){
				for(j=10;j>i+1;j--){
					a[j]=a[j-1];
				}
				a[j]=x;
			}
		}
	}
}
	for(k=0;k<11;k++){
		printf("%d ",a[k]);
	}

	printf("\n");
	system("pause");
	return 0;
}

输出结果为:
C语言:在一个有序数组中插入一个整数,并保持有序性_第1张图片
C语言:在一个有序数组中插入一个整数,并保持有序性_第2张图片
C语言:在一个有序数组中插入一个整数,并保持有序性_第3张图片

你可能感兴趣的:(C语言:在一个有序数组中插入一个整数,并保持有序性)