数据结构每日一题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;
}
相关推荐
遇见尚硅谷6 分钟前
C语言:20250728学习(指针)
c语言·开发语言·数据结构·c++·笔记·学习·算法
十八岁讨厌编程34 分钟前
【算法训练营Day17】二叉树part7
算法
YouQian7721 小时前
(AC)Playlist
算法
算法_小学生2 小时前
决策树(Decision Tree)完整解析:原理 + 数学推导 + 剪枝 + 实战
算法·决策树·剪枝
岁忧2 小时前
(LeetCode 面试经典 150 题 ) 155. 最小栈 (栈)
java·c++·算法·leetcode·面试·go
yanchao_hu3 小时前
数据结构基础内容(第二篇:线性结构)
数据结构·windows
明明如月学长3 小时前
什么你不知道 Cherry Studio 有快捷助手?
算法
拳里剑气3 小时前
C语言:顺序表(上)
c语言·开发语言·数据结构·学习方法
Vegetable_Dragon3 小时前
数论1.01
算法
Star在努力3 小时前
15-C语言:第15天笔记
c语言·笔记·算法