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

题目描述:顺序表L的元素递增有序排列,设计一个算法在插入元素x后保持该顺序表仍然递增有序排列,插入成功后返回插入元素所在位置,不成功返回-1

算法思想:在递增有序的顺序表中插入元素 x 并保持有序性,步骤如下:

合法性检查:若顺序表已满(length == MAXSIZE)或指针为空,插入失败,返回 -1。

查找插入位置:遍历顺序表,找到第一个大于等于 x 的元素的位置 i;若所有元素均小于 x,则插入到表尾(i = length)。

元素后移:从表尾开始,将位置 i 及之后的元素全部后移一位,腾出插入位置。

插入元素:将 x 存入位置 i,表长加 1,返回插入位置 i。

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

代码实现:

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

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

int InsertOrder(SeqList *L, int x) {
    // 检查表是否已满或指针为空
    if (L == NULL || L->length >= MAXSIZE) {
        return -1;
    }
    
    int i;
    // 找到第一个大于等于x的元素的位置
    for (i = 0; i < L->length; i++) {
        if (L->data[i] >= x) {
            break;
        }
    }
    // 若所有元素均小于x,i此时等于length
    
    // 从后向前移动元素,腾出插入位置
    for (int j = L->length; j > i; j--) {
        L->data[j] = L->data[j - 1];
    }
    
    L->data[i] = x;  // 插入x
    L->length++;     // 表长增加
    return i;        // 返回插入位置
}
相关推荐
baidu_162711596 小时前
linux 的list_for_each_entry
数据结构·list
艾莉丝努力练剑10 小时前
【数据结构与算法】数据结构初阶:详解顺序表和链表(五)——双向链表
c语言·开发语言·数据结构·学习·算法
Aurora_wmroy13 小时前
算法竞赛备赛——【图论】求最短路径——Floyd算法
数据结构·c++·算法·蓝桥杯·图论
lifallen14 小时前
KRaft 角色状态设计模式:从状态理解 Raft
java·数据结构·算法·设计模式·kafka·共识算法
周树皮不皮16 小时前
20250718【顺着234回文链表做两题反转】Leetcodehot100之206&92【直接过1&2明天吧】&今天计划
数据结构·链表
前端拿破轮18 小时前
面试官:二叉树的前中后序遍历,用递归和迭代分别实现🤓🤓🤓
数据结构·算法·leetcode
C++chaofan19 小时前
45. 跳跃游戏 II
java·开发语言·数据结构·算法·leetcode·游戏·职场和发展
今天你睡了嘛19 小时前
数据结构入门:像整理收纳一样简单!
数据结构
mochensage20 小时前
枚举算法入门
数据结构·算法
CQ_07121 天前
自学力扣:最长连续序列
数据结构·算法·leetcode