很简单利用C语言中的动态数组就可以搞定
举个例子
#include <stdio.h>#include <stdlib.h>
#include <malloc.h>
#include <time.h>
int main()
{
srand((unsigned)time(NULL))
int n
int new_number
printf("please input a number:\n")
scanf("%d",&n)
int *p = (int *)malloc(n*sizeof(int))
for (int i=0i<ni++)
{
p[i] = rand()%100
}
printf("the array is:\n")
for (int i=0i<ni++)
{
printf("%d\t",p[i])
}
printf("add a new number to array:\n")
scanf("%d",&new_number)
int *q = (int *)realloc(p,(n+1)*sizeof(int))
q[n] = new_number
printf("after add a new number the array is:\n")
for (int i=0i<n+1i++)
{
printf("%d\t",q[i])
}
free(q)
system("pause")
return 0
}
通过动态数组就可以在原本已经满的数组后面继续添加元素
这就要看你的数组最后一位数字是否能够被覆盖,如果最后一位的数没用的话,你就可以直接用e将该数覆盖掉,因为你的数组在定义时内存大小就已经确定了,所以长度不能增加。如果你是想改变数组的长度的话,貌似要用到链表的知识,具体的你自己找一本书看看链表的应用·····欢迎分享,转载请注明来源:内存溢出
评论列表(0条)