x = [1,2,3]
x.append(4)
或者使用extend方法在列表末位添加多个元素,参数就变成了列表
x.append([4,5,6])
或者使用insert方法在任意位置添加元素,第一个参数是插入元素的位置,第二个参数是插入元素的值
x.insert(0,-1)
方法为:输入一个数据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=0i<10i++)
printf("%4d",a[i] )
printf("\n")
printf("请输入要插入的数据:")
scanf("%d",&x)
for(i=0i<10i++)
if(a[i]>x)
break
for(j=9j>=ij--)
aLj+1] =aLj]
a[i]=x
printf("插入后数组的数据是:") ;
for(i=0i<11i++)
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函数逐个对数组元素赋值。
参考资料:
百度百科-数组
#include "stdio.h"#include "stdlib.h"
void main()
{
int *p,k,h,*q,i,j,e
printf("请输入数组中的元素的个数最大值:")
scanf("%d",&k)
p=new int[k]
if(p==NULL)
{
printf("不能分配空间!")
exit(0)
}
printf("请输入数组中的元素的个数:")//可以输入比数组长度小的个数
scanf("%d",&h)
printf("请输入数组中的元素(分别输入):\n")
for(i=0i<hi++)
scanf("%d",&p[i])
if(h==k)
{
q=new int[k+1]
if(p==NULL)
{
printf("不能分配空间!")
exit(0)
}
for(i=0i<ki++)
q[i]=p[i]
printf("请输入插入在第几个数的后面和要插入的数:")
scanf("%d%d",&j,&e)
for(i=ki>=ji--)
q[i+1]=q[i]
delete p
q[j]=e
for(i=0i<k+1i++)
printf("%d\t",q[i])
delete q
}
if(h<k)
{
printf("请输入插入在第几个数的后面和要插入的数:")
scanf("%d%d",&j,&e)
for(i=h-1i>=ji--)
p[i+1]=p[i]
p[j]=e
for(i=0i<h+1i++)
printf("%d\t",p[i])
delete p
}
}
我使用动态数组来考虑两种情况
1.数组满的,需要从新申请数组,然后后移;
2.直接后移;
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)