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

题目描述:在顺序表L的第i个位置插入新元素e,成功返回true,不成功返回false。

算法思想:在顺序表的第 i 个位置插入新元素 e 的步骤如下:

合法性检查:若插入位置 i 不满足 1 ≤ i ≤ length+1 或顺序表已满,则插入失败。

元素后移:从最后一个元素开始,将第 i 到第 length 个元素依次后移一位,腾出位置 i。

插入元素:将 e 放入位置 i-1(数组下标从 0 开始)。

更新长度:顺序表长度加 1。

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

cpp 复制代码
#include <stdbool.h> // 使用 bool 类型需包含此头文件
#define MAXSIZE 100  // 假设顺序表的最大容量

typedef struct {
    int data[MAXSIZE]; // 存储元素的数组
    int length;        // 当前表长度
} SeqList;

bool Insert(SeqList *L, int i, int e) {
    // 检查空指针、插入位置合法性及表是否已满
    if (L == NULL || i < 1 || i > L->length + 1 || L->length >= MAXSIZE) {
        return false;
    }
    
    // 从最后一个元素开始,将第 i 个之后的元素后移
    for (int j = L->length; j >= i; j--) {
        L->data[j] = L->data[j-1]; // 将前一个元素移到当前位置
    }
    
    L->data[i-1] = e; // 插入新元素到第 i 个位置(数组下标 i-1)
    L->length++;      // 表长度增加
    return true;
}
相关推荐
汀、人工智能8 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
沉鱼.448 小时前
第十二届题目
java·前端·算法
赫瑞8 小时前
数据结构中的排列组合 —— Java实现
java·开发语言·数据结构
大熊背9 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
西岸行者9 小时前
BF信号是如何多路合一的
算法
大熊背10 小时前
ISP Pipeline中Lv实现方式探究之一
算法·自动白平衡·自动曝光
罗西的思考10 小时前
【OpenClaw】通过 Nanobot 源码学习架构---(5)Context
人工智能·算法·机器学习
Liudef0611 小时前
后量子密码学(PQC)深度解析:算法原理、标准进展与软件开发行业的影响
算法·密码学·量子计算
OYpBNTQXi12 小时前
SEAL全同态加密CKKS方案入门详解
算法·机器学习·同态加密
yuannl1013 小时前
数据结构----队列的实现
数据结构