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

#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语言---typedef
c语言·c++·算法
带土13 小时前
5. enum(枚举)关键字在C/C++中的作用
c语言·c++
凉、介8 小时前
深入 QEMU Guest Agent:虚拟机内外通信的隐形纽带
c语言·笔记·学习·嵌入式·虚拟化
你怎么知道我是队长9 小时前
C语言---输入和输出
c语言·开发语言
net3m339 小时前
单片机屏幕多级菜单系统之当前屏幕号+屏幕菜单当前深度 机制
c语言·c++·算法
你怎么知道我是队长9 小时前
C语言---文件读写
java·c语言·开发语言
wu_asia10 小时前
编程技巧:如何高效输出特定倍数数列
c语言·数据结构·算法
你怎么知道我是队长10 小时前
C语言---无名位域
c语言·开发语言
码农小韩13 小时前
基于Linux的C++学习——循环
linux·c语言·开发语言·c++·算法
Q741_14713 小时前
海致星图招聘 数据库内核研发实习生 一轮笔试 总结复盘(2) 作答语言:C/C++ 哈夫曼编码 LRU
c语言·数据库·c++·算法·笔试·哈夫曼编码·哈夫曼树