大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
题目
在一维数组删除指定位置元素,现定义第一个元素位置为1,一维数组元素个数不确定,需要动态输入,并返回删除元素后的数组以及被删除的元素。
例如输入数组个数为n = 4;将要删除的数组元素位置是2;
#include <stdio.h>
#include <string.h>
#define MAXN 20
void delete_arr(int *a, int M, int *val, int *n); /*删除指定位置的元素*/
int main(void){
int N, M; //N是数组个数
int i;
int a[MAXN];
int val; //val是用来存储被删除的元素
printf("请输入数组个数:");
scanf("%d", &N);
printf("请输入将要删除元素的位置(1-%d):", N);
scanf("%d", &M); //M是待删除的元素的位置,第一个元素位置为1;
if(M < 1 || M > N)
return 0;
printf("输入数组%d个元素:", N);
for(i = 0;i < N; i++){
scanf("%d", &a[i]);
}
delete_arr(a, M, &val, &N);
printf("删除的元素是:%d\n", val);
printf("输出删除元素后的数组:");
for(i = 0;i < N; i++){
printf("%d ", a[i]);
}
printf("\n");
return 0;
}
void delete_arr(int *a, int M, int *val, int *n){
//M是位置,val是被删除的值,n是数组个数
*val = a[M - 1];
for(int i = M; i < *n; i++){
a[i - 1] = a[i];
}
*n = *n - 1;
}
输出结果如下:
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/169494.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...