数据结构每日一题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;
}
相关推荐
QiLinkOS4 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
疯狂打码的少年4 小时前
【操作系统】页面置换算法(OPT/FIFO/LRU)
算法
小O的算法实验室4 小时前
2026年CIE,优化客货协同运输:综合地铁系统的列车容量动态分配
算法
Coder_Shenshen5 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
硕风和炜6 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
我是一颗柠檬7 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农7 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
凯瑟琳.奥古斯特8 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展
Jerry9 小时前
LeetCode 203. 移除链表元素
算法
地平线开发者9 小时前
征程 6 | 工具链 QAT ObserverBase 源码解析
算法