有一个已排好序的数组,要求输入一个数后,按原来排序的规律将它插入数组中

#include <stdio.h> // 标准输入输出头文件

int main(){

// 初始化数组a,包含10个有序整数

int a[11]={1,4,6,9,13,16,19,28,40,100};

int temp1,temp2,number,end,i,j;

// 打印数组a的当前内容

printf("请输入数组a:\n");

for(i=0;i<10;i++){

printf("%5d ",a[i]);

}

printf("\n");

// 从用户处接收要插入的数字

printf("请输入插入数字:");

scanf("%d",&number);

end=a[9]; // 获取数组最后一个元素的值

if(number>end){ // 如果插入数字大于数组中最大的数,则直接添加到数组末尾

a[10]=number;

}

else{ // 如果插入数字小于或等于数组中最大的数,则找到合适的位置插入

for(i=0;i<10;i++){

if(a[i]>number){ // 找到第一个大于插入数字的元素

temp1=a[i];

a[i]=number; // 插入数字到找到的位置

// 交换元素,使得插入数字后的数组依然有序

for(j=i+1;j<11;j++){

temp2=a[j];

a[j]=temp1;

temp1=temp2;

}

break;

}

}

}

// 打印插入数字后的数组内容

printf("目前数组a:\n");

for(i=0;i<11;i++){

printf("%5d ",a[i]);

}

printf("\n");

return 0; // 程序正常结束

}

相关推荐
wangjialelele17 分钟前
Linux下的IO操作以及ext系列文件系统
linux·运维·服务器·c语言·c++·个人开发
wengqidaifeng3 小时前
数据结构(三)栈和队列(上)栈:计算机世界的“叠叠乐”
c语言·数据结构·数据库·链表
VekiSon3 小时前
Linux内核驱动——设备树原理与应用
linux·c语言·arm开发·嵌入式硬件
BlackQid3 小时前
深入理解指针Part5——回调函数及应用
c语言
日拱一卒——功不唐捐3 小时前
字符串匹配:暴力法和KMP算法(C语言)
c语言·算法
lcj25114 小时前
深入理解指针(4):qsort 函数 & 通过冒泡排序实现
c语言·数据结构·算法
4311媒体网5 小时前
C语言操作符全解析 C语言操作符详解
java·c语言·jvm
二年级程序员5 小时前
一篇文章掌握“顺序表”
c语言·数据结构
傻乐u兔6 小时前
C语言进阶————指针4
c语言·开发语言
历程里程碑6 小时前
Linux22 文件系统
linux·运维·c语言·开发语言·数据结构·c++·算法