定义一个能容纳10个元素的整形数组a,从键盘读取9个整数存放到前9个数组元素中。
一.
从键盘读取一个整数n和位置p(0<=p<=8),插入n到数组a中,插入位置:下标p。要求插入点及后续的数组元素都要后移动。
代码如下:
int main()
{
int arr[9], i, p, num;
//输入数组,对数组前9-1个元素赋值
for (i = 0; i <= 7;i++)
scanf("%d", &arr[i]);
//输入要插入数的下标p
printf("输入要插入数的下标p");
scanf("%d", &p);
//将p到(9-1)的数往后移动一个下标
for (i = 7; i >=p;i--)
arr[i+1] = arr[i];
//输入要插入的数num
printf("输入要插入的数:");
scanf("%d", &num);
arr[p] = num;
for(i=0;i<=8;i++)
printf("%d", arr[i]);
return 0;
}
运行结果:
代码解读:
首先对一个数组进行赋值,因为数组中的元素要向后面移动一个下标,所以定义数组为n个元素,对n-1个元素进行赋值。
然后选定要插入数的数组下标p,从i=n-2开始到p,依次a[i]=a[i+1],(注意此处不能从p到n-1,因为会出现覆盖现象,读者可以自己尝试体验一下).
接着输入要插入的数赋给a[p],利用循环把新数组中的数打印出来。
二.
删除数组中某一个元素。
代码如下
int main()
{
int arr[6], i, p;
for (i = 0; i <= 5; i++)
scanf("%d", &arr[i]);
printf("输入要删除的元素下标p;");
scanf("%d", &p);
for (i = p + 1; i <= 5; i++)
arr[i - 1] = arr[i];
for (i = 0; i <= 4; i++)
printf("%d", arr[i]);
return 0;
}
运行结果如下:
对于代码里面的内容,读者可以根据上一道题来研究。
往期回顾:
C语言编程练习:验证哥德巴赫猜想 进制转换 rand函数-CSDN博客
C语言——函数基本知识(三)-CSDN博客
C语言——函数基本知识(二)-CSDN博客
C语言 ——函数基本知识(一)-CSDN博客
“山林不向四季起誓,荣枯随缘”——C语言(爱心+祝福语)代码分享_爱心代码朋友圈文案-CSDN博客
C语言——二分法查找讲解_c语言二分法查找一个数-CSDN博客
C语言穷举法算法经典题型(二)_百钱百鸡问题c语言-CSDN博客
C语言穷举法算法经典题型(一)_c语言穷举法经典例题-CSDN博客
C语言算法经典基础题型——求一个数的回文数(两种方法)_c语言for循环求各位数字回文数-CSDN博客
C语言基础入门(小白)三种方法解决幽灵换行符问题_如何处理scanf输入时的换行符?-CSDN博客