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

#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; // 程序正常结束

}

相关推荐
黑听人2 小时前
【力扣 简单 C】141. 环形链表
c语言·开发语言·数据结构·算法·leetcode
liujing102329296 小时前
Day13_C语言基础&项目实战
c语言·开发语言
sunny-ll11 小时前
【C++】详解vector二维数组的全部操作(超细图例解析!!!)
c语言·开发语言·c++·算法·面试
西装没钱买12 小时前
C语言多进程TCP服务器与客户端
服务器·c语言·tcp/ip·进程
嵌入式@秋刀鱼12 小时前
《第五章-心法进阶》 C++修炼生涯笔记(基础篇)指针与结构体⭐⭐⭐⭐⭐
c语言·开发语言·数据结构·c++·笔记·算法·visual studio code
whoarethenext13 小时前
使用 C/C++的OpenCV 裁剪 MP4 视频
c语言·c++·opencv
tiandyoin13 小时前
如何给 C:\Windows\WinSxS\ 瘦身?
c语言·开发语言·windows
呆呆的小鳄鱼15 小时前
如何刷新缓冲区(c++、c、linux)
linux·c语言·c++
W说编程16 小时前
算法导论第三章:数据结构艺术与高效实现
c语言·数据结构·算法
is081517 小时前
C语言运行时
c语言·开发语言