当前编程题:中山外包-实验6-数组程序设计
2. 已知一初始化的数组a[11]={1,2,3,4,5,6,7,8,9,0}。1)输入x1和n1,将数x1插入在数组的n1(下标)处,原数组从该处之后的元素顺序后移,如果插入的位置不合法,则插在数组的最后一个元素之后;2)执行完上述操作之后,输入n2,将数组下标为n2处的元素删除,该处之后的元素顺序前移,如果删除的位置不合法,则删除数组的第一个元素(下标为0)
输入:两行
第一行,2个数,分别代表x1和n1
第二行,一个数,表示n2
输出:三行,每个数占5列
第一行,10个数,表示原数组元素
第二行,11个数,表示进行插入操作之后的数组
第三行,10个数,代表进行插入之后,又进行了删除操作之后的数组
数组指定位置插入和删除
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答
- threenewbee 2019-11-07 10:55关注
#include <stdio.h> void printarr(int a[], int n) { for (int i = 0; i < n; i++) printf("%d ", a[i]); printf("\n"); } void ins(int a[], int n, int x1, int n1) { if (n1 > n || n1 < 0) n1 = n; for (int i = n; i > n1; i--) a[i] = a[i - 1]; a[n1] = x1; } void del(int a[], int n, int n2) { if (n2 >= n || n2 < 0) n2 = 0; for (int i = n2; i < n - 1; i++) a[i] = a[i + 1]; } int main() { int x1, n1, n2; scanf("%d%d", &x1, &n1); scanf("%d", &n2); int a[11]={1,2,3,4,5,6,7,8,9,0}; printarr(a, 10); ins(a, 10, x1, n1); printarr(a, 11); del(a, 11, n2); printarr(a, 10); return 0; }
100 3
7
1 2 3 4 5 6 7 8 9 0
1 2 3 100 4 5 6 7 8 9 0
1 2 3 100 4 5 6 8 9 0本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 关于#java#的问题,请各位专家解答!
- ¥15 急matlab编程仿真二阶震荡系统
- ¥20 TEC-9的数据通路实验
- ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
- ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
- ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
- ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
- ¥15 如何实现H5在QQ平台上的二次分享卡片效果?
- ¥30 求解达问题(有红包)
- ¥15 请解包一个pak文件