数据结构每日一题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;
}
相关推荐
jerryinwuhan9 分钟前
SVM案例分析
算法·机器学习·支持向量机
高山上有一只小老虎17 分钟前
购物消费打折
java·算法
郝学胜-神的一滴32 分钟前
计算机图形中的法线矩阵:深入理解与应用
开发语言·程序人生·线性代数·算法·机器学习·矩阵·个人开发
m0_591338911 小时前
day8鹏哥C语言--函数
c语言·开发语言·算法
_OP_CHEN1 小时前
算法基础篇:(二)基础算法之高精度:突破数据极限
算法·acm·算法竞赛·高精度算法·oj题
一只老丸1 小时前
HOT100题打卡第30天——技巧
算法
西岭千秋雪_1 小时前
Zookeeper数据结构
java·数据结构·分布式·zookeeper
Bi_BIT1 小时前
代码随想录训练营打卡Day38| 动态规划part06
算法·动态规划
手握风云-2 小时前
回溯剪枝的“减法艺术”:化解超时危机的 “救命稻草”(三)
算法·剪枝
元亓亓亓2 小时前
LeetCode热题100--46. 全排列--中等
算法·leetcode·职场和发展