数据结构每日一题day5(顺序表)★★★★★

题目描述:从顺序表L中删除最小值元素并由函数返回被删元素的值。(假设顺序表L有最小值且最小值唯一)

算法思想:

合法性检查:若顺序表为空或指针为空,返回特定错误值(如-1,根据题目假设可省略)。

查找最小值位置:遍历顺序表,记录当前最小值及其下标。

保存并删除元素:将最小值元素保存后,将其后所有元素前移一位覆盖该位置。

更新表长:顺序表长度减1,返回被删元素值。

复杂度分析:时间复杂度O(n)空间复杂度O(1)

代码实现:

cpp 复制代码
#include <stdio.h>
#define MAXSIZE 100  // 假设顺序表最大容量

typedef struct {
    int data[MAXSIZE];
    int length;
} SeqList;

int DeleteMin(SeqList *L) {
    // 检查空指针或空表(题目假设存在最小值,此检查可省略)
    if (L == NULL || L->length == 0) {
        return -1;  // 返回错误标记
    }

    int min_index = 0;              // 初始假设第0个元素最小
    int min_value = L->data[0];     // 保存当前最小值

    // 遍历查找最小值位置
    for (int i = 1; i < L->length; i++) {
        if (L->data[i] < min_value) {
            min_value = L->data[i];
            min_index = i;
        }
    }

    // 将最小值后的元素前移,覆盖删除位置
    for (int i = min_index + 1; i < L->length; i++) {
        L->data[i - 1] = L->data[i];
    }

    L->length--;    // 表长减1
    return min_value; // 返回被删除的最小值
}

int main() {
    // 示例测试
    SeqList L = {{5, 3, 2, 8, 1}, 5};
    int min = DeleteMin(&L);
    printf("被删除的最小值:%d\n", min);        // 输出:1
    printf("删除后的顺序表:");
    for (int i = 0; i < L.length; i++) {
        printf("%d ", L.data[i]);           // 输出:5 3 2 8
    }
    return 0;
}
相关推荐
Non importa15 分钟前
【初阶数据结构】树——二叉树(上)
c语言·数据结构·学习·算法
Tech Synapse2 小时前
基于Surprise和Flask构建个性化电影推荐系统:从算法到全栈实现
python·算法·flask·协同过滤算法
終不似少年遊*2 小时前
国产之光DeepSeek架构理解与应用分析04
人工智能·python·深度学习·算法·大模型·ds
天天扭码2 小时前
一分钟解决 | 高频面试算法题——最大子数组之和
前端·算法·面试
杰杰批2 小时前
力扣热题100——矩阵
算法·leetcode·矩阵
明月看潮生3 小时前
青少年编程与数学 02-016 Python数据结构与算法 28课题、图像处理算法
图像处理·python·算法·青少年编程·编程与数学
_GR3 小时前
2025年蓝桥杯第十六届C&C++大学B组真题及代码
c语言·数据结构·c++·算法·贪心算法·蓝桥杯·动态规划
心想事“程”3 小时前
决策树详解+面试常见问题
算法·决策树·机器学习
shinelord明4 小时前
【软件系统架构】事件驱动架构
数据结构·设计模式·架构·系统架构·软件工程
照海19Gin4 小时前
数据结构中的宝藏秘籍之广义表
c语言·数据结构·算法