PTA:用函数实现从数列中删除一个数

题目:

编写一个函数实现:删除n个元素的数列中下标为k的元素。

测试程序将输入一个下标值,调用本函数,删除数列{1,4,13,9,6,11,18,14,25}中该下标位置的元素,并输出删除后的数列。

函数接口定义:

void deleted ( int a[], int n, int k);

其中 a 、n和 k 都是用户传入的参数。 a是数列所在数组的首地址; n 是数列元素个数, k 是[0, 8]区间内的个位数。

裁判测试程序样例:

c 复制代码
#include <stdio.h>
void deleted ( int a[], int n, int k);
int main()
{
    int a[9]={1,4,13,9,6,11,18,14,25},k;
    int i;
    scanf("%d",&k);
    deleted(a,9,k);
    for(i=0;i<8;i++)
         printf("%4d", a[i]);
    return 0;
 }
/*请将答案写在这里*/

输入样例:

输入一个[0,8]间的个位数

0

输出样例:

输出数组中各元素占4列

4 13 9 6 11 18 14 25

解题过程

c 复制代码
#include <stdio.h>
void deleted(int a[], int n, int k){
    if (k < 0 || k >= n){
        return;
    }
    for (int i = k; i < n - 1; i++) {
        a[i] = a[i + 1]; 
    }
}
相关推荐
暮冬-  Gentle°几秒前
C++代码依赖分析
开发语言·c++·算法
2301_763891953 分钟前
泛型编程与STL设计思想
开发语言·c++·算法
j_xxx404_5 分钟前
蓝桥杯基础--进制转换
开发语言·数据结构·c++·算法·职场和发展·蓝桥杯
阿Y加油吧13 分钟前
力扣链表高频题:两两交换节点 + K个一组翻转链表(保姆级思路+满分代码)
算法·leetcode·链表
Boop_wu17 分钟前
[Java 算法] 动态规划2
算法·leetcode·动态规划
yugi98783822 分钟前
非支配排序遗传算法NSGA-III详解与MATLAB实现
算法
ballball~~23 分钟前
ISP-Tone Mapping
图像处理·算法·isp
米粒124 分钟前
力扣算法刷题 Day22
算法·leetcode·职场和发展
科德航空的张先生24 分钟前
飞行错觉(空间定向障碍)地面模拟训练系统
人工智能·算法
老四啊laosi26 分钟前
[双指针] 2. 力扣--复写零
算法·leetcode·双指针·复写零