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

题目描述:将两个有序顺序表A和B合并为一个新的有序顺表返回 true,合并失败则返回 false。

算法思想:

输入检查:若A、B或C为空指针,或合并后总长度超过顺序表最大容量,返回false。

双指针遍历:使用两个指针分别遍历A和B,比较当前元素大小,将较小者插入C,直至其中一个表遍历完毕。

剩余元素处理:将未遍历完的表中剩余元素全部追加到C中。

更新表长:设置C的length为合并后总长度,返回true。

复杂度分析:

时间复杂度:O(m+n),其中m、n为A、B的长度,需遍历所有元素。

空间复杂度:O(1),仅需常数级辅助变量。

代码实现:

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

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

bool Merge(SeqList *A, SeqList *B, SeqList *C) {
    // 检查空指针或合并后长度超限
    if (A == NULL || B == NULL || C == NULL || 
        (A->length + B->length) > MAXSIZE) {
        return false;
    }

    int i = 0, j = 0, k = 0;  // i遍历A,j遍历B,k填充C
    // 双指针遍历,按序插入较小元素
    while (i < A->length && j < B->length) {
        if (A->data[i] <= B->data[j]) {
            C->data[k++] = A->data[i++];
        } else {
            C->data[k++] = B->data[j++];
        }
    }

    // 处理A或B的剩余元素
    while (i < A->length) {
        C->data[k++] = A->data[i++];
    }
    while (j < B->length) {
        C->data[k++] = B->data[j++];
    }

    C->length = k;  // 更新C的实际长度
    return true;
}
相关推荐
跳跳糖炒酸奶20 分钟前
第四章、Isaacsim在GUI中构建机器人(2):组装一个简单的机器人
人工智能·python·算法·ubuntu·机器人
绵绵细雨中的乡音36 分钟前
动态规划-第六篇
算法·动态规划
程序员黄同学1 小时前
动态规划,如何应用动态规划解决实际问题?
算法·动态规划
march_birds1 小时前
FreeRTOS 与 RT-Thread 事件组对比分析
c语言·单片机·算法·系统架构
斯汤雷2 小时前
Matlab绘图案例,设置图片大小,坐标轴比例为黄金比
数据库·人工智能·算法·matlab·信息可视化
云 无 心 以 出 岫2 小时前
贪心算法QwQ
数据结构·c++·算法·贪心算法
俏布斯2 小时前
算法日常记录
java·算法·leetcode
独好紫罗兰2 小时前
洛谷题单3-P5719 【深基4.例3】分类平均-python-流程图重构
开发语言·python·算法
SheepMeMe3 小时前
蓝桥杯2024省赛PythonB组——日期问题
python·算法·蓝桥杯
随便昵称3 小时前
蓝桥杯专项复习——前缀和和差分
c++·算法·前缀和·蓝桥杯