数据结构每日一题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;
}
相关推荐
仰泳的熊猫3 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
无极低码6 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发6 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
罗超驿7 小时前
独立实现双向链表_LinkedList
java·数据结构·链表·linkedlist
superior tigre7 小时前
22 括号生成
算法·深度优先
努力也学不会java8 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎9 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan9 小时前
朱梁万有递归元定理,重构《易经》
算法·重构
智者知已应修善业9 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机