数据结构每日一题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;
}
相关推荐
学习中的码虫25 分钟前
数据结构中的高级排序算法
数据结构·算法·排序算法
山北雨夜漫步30 分钟前
机器学习 Day17 朴素贝叶斯算法-----概率论知识
人工智能·算法·机器学习
是店小二呀1 小时前
【优选算法 | 字符串】字符串模拟题精选:思维+实现解析
android·c++·算法
成工小白1 小时前
【Linux】进程地址空间
linux·算法
凤年徐1 小时前
【C/C++】自定义类型:结构体
c语言·开发语言·c++·经验分享·笔记·算法
闪电麦坤951 小时前
数据结构:树(Tree)
数据结构
Inverse1622 小时前
C语言_自定义类型:结构体
c语言·开发语言·算法
Musennn2 小时前
102. 二叉树的层序遍历详解:队列操作与层级分组的核心逻辑
java·数据结构·算法·leetcode
越来越无动于衷2 小时前
java数组题(5)
java·算法
理论最高的吻2 小时前
77. 组合【 力扣(LeetCode) 】
c++·算法·leetcode·深度优先·剪枝·回溯法