数组~插队

题目描述

有一个按照升序已排好的9个元素的数组,今输入一个数要求按原来排序的规律将它插入数组中。

输入

第一行,原始数列。 第二行,需要插入的数字。

输出

排序后的数列

样例输入

1 7 8 17 23 24 59 62 101
50

样例输出

1
7
8
17
23
24
50
59
62
101


复制代码
 1 #include<stdio.h>
 2 int main(){
 3     int n;
 4     int a[15];
 5     int i;
 6     //第一个循环输入数组
 7     for(i=1;i<=9;i++){
 8         scanf("%d",&a[i]);
 9     }
10     scanf("%d",&n);
11     //第二个循环找插入数字的位置
12     // while(n>a[i]){
13     //     i++;
14     // }
15     //第三个循环插入后对原数组的下表后移
16     //第四个循环输出
17 
18     for(int j=1;j<=9;j++){
19         if(n>=a[j-1] && n<=a[j]){
20             printf("%d\n",n);
21         }
22         printf("%d\n",a[j]);
23     }
24     return 0;
25 }
复制代码

solution:

1 不要把插入数放进数组里进行判断或者输出,增加移动数组下标的操作~在输出数组的过程中,插入数找到合适的位置便立刻进行输出后,继续输出数组剩下的数

posted on   罗小罗佳油  阅读(96)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程
点击右上角即可分享
微信分享提示