C语言中,数组是一组连续的相同类型的数据集合。 所以要在数组中插入元素,需要按照以下步骤:
1、找到插入点;
2、将插入点所在元素,及之后的所有元素,都向后移动一个单位;
3、将插入点赋值为要插入的元素。
以固定位置插入,代码举例如下:
#include <stdio.h>void insert(int *a, int n, int i, int v)
//将长度为n的数组a, 下标为i的位置插入值为v的元素。 插入后,数组长度为n+1.
{
int j
for(j = n-1 j>=i j --)//将i及以后的后移一位。 由于是固定位置插入,所以不需要查找插入位置。
a[j+1] = a[j]
a[i] = v//插入元素。
}
int main()
{
int a[5] = {1,3,6,7}/五个元素数组,初始化四个值。
int i
insert(a, 4, 2, 5)//将5插入到a[2]位置。
for(i = 0 i < 5 i ++)
printf("%d ", a[i])//输出结果,为1 3 5 6 7
return 0
}
您好,很高兴回答您的问题。break是在遇到判断条件为真时才执行。这里是当遇到第一个比输入的数大的时候,就用break结束循环,目的就是找到了需要存放这个后来输入的数据的位置。后面的for循环就是将之前找到的位置及之后的数据全部往后挪一位,然后再把新输入的数据放到这个位置上。
不过您程序中给的原始数列也不是排好序的数哦,所以输入数据排序好像不太具有说服力哦。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)