C语言有一个已排好序的整型数组,有10个元素,要求从键盘输入一个数后,按原来排序的规律将它插入数组中

 我来答
小夏聊生活
高能答主

2019-12-07 · 专注于分享生活知识,热爱生活
小夏聊生活
采纳数:447 获赞数:114613

向TA提问 私信TA
展开全部

源代码如下:

#include <stdlib.h>

#include <stdio.h>

int main()

{

int a[20],i,n,x,k;

printf("请输入一组顺序数(从小到大的顺序):");

for( i=0; ;i++ )

{

scanf("%d",&a[i]);

if( getchar() == '\n' )

break;

}

n = i + 1;        //n表示数组内数字的个数

printf("请输入需要插入的数:");

scanf("%d",&x);

for(i=0;i<n;i++)

{

if( x<= a[i] )

{

for( k= n-1; k >= i; k--)

{

a[k+1]=a[k];

}

a[i]=x;

break;

}

}

for(i=0;i<=n; i++)

{

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

}

printf("\n");

system("pause");

}

扩展资料

1、C语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量。

2、数组的声明并不是声明一个个单独的变量,比如 number0、number1、...、number99,而是声明一个数组变量。

问明6E
高粉答主

2019-06-04 · 每个回答都超有意思的
知道答主
回答量:279
采纳率:100%
帮助的人:12.9万
展开全部

#include<stdio.h>

intmain()

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

inttemp,i=0,j=0;

scanf("%d",&temp);

for(i=9;i>=0;i--)

if(temp<a[i]){

a[i+1]=a[i];

}else{

a[i+1]=temp;

break;

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

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

system("pause");

return0;

运行结果:

扩展资料:

system用法

system函数的用法,需要包含头文件#include<process.h>

这个函数跟他的参数没有任何关系,他的参数是字符串;

intsystem(constchar*command);

int_wsystem(constwchar_t*command);

command:Commandtobeexecuted

可以用来执行指定路径下的可执行文件,其中可以包含一些DOS命令,在这里使用和在CMD的命令行中执行这条命令的效果相同,比如:

system("C:\\MT_Sqlconn.exe>C:\\out.log");

这行代码的意思就是,执行C:\\MT_Sqlconn.exe,并把这个文件的输出结果重定向到C:\\out.log文件中,以前通过printf打印到标准输出的结果全system("pause");部打印到了C:\\out.log文件中。

system函数是可以调用一些DOS命令,比如

system("cls");//清屏,等于在DOS上使用cls命令system("notepad")//打开记事本程序system("ipconfig>>123.txt");//输出ipconfig查询出的结果到当前目录的123.txt文件中,每次都是覆盖的。

system(执行shell命令)

相关函数fork,execve,waitpid,popen

表头文件#include<stdlib.h>,

例:

#include<stdlib.h>

main()

system(“ls-al/etc/passwd/etc/shadow”);



本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
phd121212
推荐于2017-11-25 · TA获得超过494个赞
知道小有建树答主
回答量:114
采纳率:0%
帮助的人:36.3万
展开全部

下面是一个升序的整型数组,从键盘插入插入一个数,使原规律不变的编程:

 

#include<stdio.h> 

int main() 

    int m,i,j,t; 

    int a[11]={1,2,4,5,7,8,9,10,22,66};

 scanf("%d",&m); 

 

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

   if(m<a[i]) 

      { for(j=9;j>=i;j--) 

           { t=a[j+1];a[j+1]=a[j];a[j]=t;} 

            a[i]=m; }   

 

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

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

    return 0;

 

 

 

希望对你有帮助,望采纳;

谢谢。。。。。

 

 

 

 

 

本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友3123d73db
2013-01-04
知道答主
回答量:26
采纳率:0%
帮助的人:12.7万
展开全部
//那你需要定义一个新数组了,程序如下吧:
#include <stdio.h>
int main() {
int a[10] = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 }; //加入是这样的数组,要么升序,要么降序;
int b[11] = { 0 };
int insert = 0;
int i = 0;
int j = 0;
int insert_already = 0;
printf("Enter the number\n");
scanf("%d", &insert);
//判断升序还是降序
if (a[0] > a[9]) //降序,插入到比他小的前面
{
while (j < 11) {
if (insert_already == 0) { //尚未插入该值
if (insert > a[i]) {
b[j] = insert;
i--;
insert_already = 1; //已经插入该值
} else {
b[j] = a[i];
}
i++;
j++;
} else //已经插入该值
{
b[j] = a[i];
i++;
j++;
}
}
} else //升序,插入到比他大的前面前面
{
while (j < 11) {
if (insert_already == 0) {
if (insert < a[i]) {
b[j] = insert;
i--;
insert_already = 1;
} else {
b[j] = a[i];
}
i++;
j++;
} else //已经插入该值
{
b[j] = a[i];
i++;
j++;
}
}
}
//输出b[11];
for (i = 0; i < 11; i++) {
printf("%d\n", b[i]);
}
return 0;
}
//给分吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
斩不断的风
2013-01-04 · 超过50用户采纳过TA的回答
知道小有建树答主
回答量:228
采纳率:0%
帮助的人:123万
展开全部
用循环找到一个位置,使这个位置前的数都小于这个数,并且后面的数不小于这个数,再把后面的数往后移1位,把这个数插入
追问
额 要程序设计…这是我们的考试题…你能把编程给我么?非常感谢!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式