在c语言中,如何在数组中插入一个数

如题所述

方法为:输入一个数据x,将数组中的数据与x逐一比较,如果大于x,记录下数据的下标,然后此数据下标和其后的数据的下标都加一,相当于都向后挪一位,然后将x赋值给数组的那个下标。

#include<stdio.h>

int main()

int i, j, k, x, a[11] =(3, 6, 7, 9, 12, 14, 15, 27, 29, 31) ;

printf("插入前数组的数据是:") ;

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

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

printf("\n") ;

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

scanf("%d",&x) ;

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

if(a[i]>x)

break;

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

aLj+1] =aLj] ;

a[i]=x;

printf("插入后数组的数据是:") ;

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

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

return 0;

扩展资料:

数组的使用规则:

1.可以只给部分元素赋初值。当{ }中值的个数少于元素个数时,只给前面部分元素赋值。例如:static int a[10]={0,1,2,3,4};表示只给a[0]~a[4]5个元素赋值,而后5个元素自动赋0值。

2.只能给元素逐个赋值,不能给数组整体赋值。例如给十个元素全部赋1值,只能写为:static int a[10]={1,1,1,1,1,1,1,1,1,1};而不能写为:static int a[10]=1;(请注意:在C、C#语言中是这样,但并非在所有涉及数组的地方都这样,数据库是从1开始。)

3.如不给可初始化的数组赋初值,则全部元素均为0值。

4.如给全部元素赋值,则在数组说明中, 可以不给出数组元素的个数。例如:static int a[5]={1,2,3,4,5};可写为:static int a[]={1,2,3,4,5};动态赋值可以在程序执行过程中,对数组作动态赋值。这时可用循环语句配合scanf函数逐个对数组元素赋值。

参考资料:

百度百科-数组

温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2017-11-28
程序1:这个是输入10个数 先排序 再插入一个数 再排序 数组大小你可以自己更改
#include <stdio.h>
void main()
{
int i,j,m,temp,a[11];
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<10;i++)
for(j=i+1;j<10;j++)
if(a[i]>a[j])
{
temp=a[i];
a[i]=a[j];
a[j]=temp;
}
for(i=0;i<10;i++)
printf("%d ",a[i]);
scanf("%d",&m);
for(i=0;i<10;i++)
if(a[i]>m)
{
temp=a[i];
a[i]=m;
m=temp;
}
a[10]=m;
for(i=0;i<11;i++)
printf("%d ",a[i]);
printf("\n");
}
程序2:如果题中已给排好序的数组 不必自己输入的话
#include <stdio.h>
void main()
{int a[11]={1,4,6,9,13,16,19,28,40,100};
int temp1, temp2,number,end,i,j;
printf("array a:\n");
for (i=0;i<10;i++)
printf("%5d",a[i]);
printf("\n");
printf("insert date:");
scanf("%d",&number);
end=a[9];
if(number>end)
a[10]=number;
else
{for(i=0;i<10;i++)<br/> {if(a[i]>number)<br/> {temp1=a[i];<br/> a[i]=number;<br/> for(j=i+1;j<11;j++)<br/> {temp2=a[j];<br/> a[j]=temp1;<br/> temp1=temp2;<br/> }
break;
}
}
}
printf("now,array a:\n");
for(i=0;i<11;i++)
printf("%d ",a[i]);
}本回答被网友采纳
第2个回答  2013-08-01
楼主能说具体点吗。有很多方法,比如用字符串连接的函数,strc...什么什么的函数,还可以直接插入一个数,和数组中的数比较大小
第3个回答  2019-12-21
有一个已排好序(从大到小)的数组有5个元素,从键盘输入一个数,要求按原排序的规律将它插入到数组中。1.#includevoid main({int i,x,j; int {1,5,10,15,20}; scanf("%d",&x);for(i=0;i<5;i++) if(x2.j=i; /*当这个数比当前数小时,用j记住当前位置,即j=i,中断循环。……
第4个回答  2013-08-01
比如在第n个数中插入一个m

在c语言中,如何在数组中插入一个数
方法为:输入一个数据x,将数组中的数据与x逐一比较,如果大于x,记录下数据的下标,然后此数据下标和其后的数据的下标都加一,相当于都向后挪一位,然后将x赋值给数组的那个下标。include<stdio.h> int main()int i, j, k, x, a[11] =(3, 6, 7, 9, 12, 14, 15, 27, 29...

在c语言中,怎样在一个数组中插入一数
q[i]=p[i];printf("请输入插入在第几个数的后面和要插入的数:");scanf("%d%d",&j,&e);for(i=k;i>=j;i--)q[i+1]=q[i];delete p;q[j]=e;for(i=0;i<k+1;i++)printf("%d\\t",q[i]);delete q;} if(h<k){ printf("请输入插入在第几个数的后面和要插入的数:"...

c语言中如何输入数组中的数
printf("这几个同学的最高分为:%f\\n平均成绩为:%.2f\\n",max,sum\/10);return 0;}

关于C语言在数组里插入一个数
void main(){ int a[11]={93,58,2,65,4,30,24,45,78,122}; \/\/\/这里定义数组的时候,要写上11,否则会认为该数组只有10个元素,那样的话,无法对其进行插入的。其他地方没有错误 int i,j,temp,n;for(i=0;i<10;i++)for(j=0;j<9-i;j++)if(a[j]>a[j+1]){temp=a[j];a...

c语言 在数组中插入一个数该怎么写
\/\/---数组的插入操作--- printf("\\n 请输入要插入的元素值:");scanf ("%d",&value);printf("请输入要插入的位置(1..%d): ",n+1);scanf("%d",&location);if((location<1)||(location>n+1)){ printf("你输入的位置超出范围!!\\n");return;} if(n==MAXNUMBER){ printf("数组...

c语言 向有序数组中插入一个数,保持原顺序不变,将新数组输出
inta[17]={1,5,9,14,23,34,45,56,67,78,89,99,105,126,156};scanf("%d,%d",&m,&n);for(i=0;i<15;i++)\/\/这里i<16;改成i<15;因为插入前数组有15个元素 { if(m<=a[i])\/\/这里m<a[i]改成m<=a[i]{ for(j=14;j>=i;j--)a[j+1]=a[j];a[i]=m;break;\/\/...

C语言如何把输入进去的数放到数组中
有两种方式:1 先输入数值,在存放在数组的对应位置中,即赋值给对应元素。如 scanf("%d",&i);a[k] = i;就是先输入到变量i中,然后把i存储在a的第k个元素中。2 直接输入到数组对应元素中。如 scanf("%d",&a[k]);与1中的例子是相同效果,只是减少了中间变量的使用。

在c语言中,将一个数插入一个数组中的程序怎么写?
有一个已排好序(从大到小)的数组有5个元素,从键盘输入一个数,要求按原排序的规律将它插入到数组中1.#include<stdio.h>void main({int i,x,j; int {1,5,10,15,20}; scanf("%d",&x);for(i=0;i<5;i++) if(x=j;i--)a[i+1]=a[i]; \/*将位置j以后的数据都向后移一位...

C语言中数组名直接加数字的用法?请举例
\/\/切记一点数组名代表数组的首地址,还有就是arr[i] == *(arr + i)#include <stdio.h>int main(void){ int arr[5] = {37,10,30,87,10}; int len = 5; int i,*p; p = arr; \/\/第一种循环数组的方法 printf("第一种循环数组的方法:\\n"); for(i=0;i<...

在c语言中怎么输入一组数字存储在数组里
printf("请输入一个数字:");scanf("%d", &num);int first = 0;int last = N-1;int half = 0;bool bfind = false;time_t start, end;start = time(NULL);do { half = (first+last)\/2;;if( num == iarray[half]){ bfind = true;break;} else if( num > iarray[half]...

相似回答