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

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

}

相关推荐
Benmao⁢35 分钟前
C语言期末复习笔记
c语言·开发语言·笔记·leetcode·面试·蓝桥杯
无限进步_4 小时前
深入理解 C/C++ 内存管理:从内存布局到动态分配
c语言·c++·windows·git·算法·github·visual studio
liu****5 小时前
9.二叉树(一)
c语言·开发语言·数据结构·算法·链表
铁手飞鹰6 小时前
[HAL库分析—GPIO]
c语言·stm32·单片机·嵌入式硬件
水饺编程6 小时前
第3章,[标签 Win32] :处理 WM_PRINT 消息
c语言·c++·windows·visual studio
虚假程序设计6 小时前
pythonnet 调用C接口
c语言·python
松涛和鸣8 小时前
DAY27 Linux File IO and Standard IO Explained: From Concepts to Practice
linux·运维·服务器·c语言·嵌入式硬件·ubuntu
myw0712059 小时前
湘大oj-数码积性练习笔记
c语言·数据结构·笔记·算法
了一梨9 小时前
网络编程:TCP Socket
linux·c语言·tcp/ip
EXtreme359 小时前
【数据结构】手撕队列(Queue):从FIFO底层原理到高阶应用的全景解析
c语言·数据结构·链表·队列