当前位置: 首页 > article >正文

数据结构每日一题day1

题目描述:设计一个高效算法,讲顺序表L的所有元素逆置。要求算法空间复杂度为O(1)

算法思想:采用双指针法。通过交换首尾对应位置的元素实现逆置,具体步骤如下:

初始化指针:用两个下标分别指向顺序表的首元素(下标0)和末元素(下标length-1)。

交换元素:每次交换两个下标对应的元素,然后首指针右移,尾指针左移。

终止条件:当首指针超过或等于尾指针时停止,确保所有元素被交换一次。

代码实现:

#include <stdio.h>

#define MAXSIZE 100 // 假设顺序表最大长度为100

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

void reverse(SeqList *L) {
    // 处理空指针或空表的特殊情况
    if (L == NULL || L->length <= 0) {
        return;
    }
    int temp; // 临时变量用于交换,空间复杂度O(1)
    for (int i = 0; i < L->length / 2; i++) { // 遍历前一半元素
        // 计算对称位置j
        int j = L->length - 1 - i;
        // 交换data[i]和data[j]
        temp = L->data[i];
        L->data[i] = L->data[j];
        L->data[j] = temp;
    }
}

int main() {
    // 示例测试
    SeqList list = {{1, 2, 3, 4, 5}, 5};
    reverse(&list);
    printf("逆置后顺序表内容:");
    for (int i = 0; i < list.length; i++) {
        printf("%d ", list.data[i]);
    }
    return 0;
}

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


http://www.kler.cn/a/599796.html

相关文章:

  • docker模拟Dos_SYN Flood拒绝服务攻击 (Ubuntu20.04)
  • uniapp处理流式请求
  • PLY格式文件如何转换成3DTiles格式——使用GISBox软件实现高效转换
  • [深度学习]特征提取和无监督
  • 精通服务器推送事件(SSE)与 Python 和 Go 实现实时数据流 [特殊字符]
  • Qt6相对Qt5的主要提升(AI总结)
  • systemd-networkd 的 *.network 配置文件中的 [Network] 和 [Address] 中的 Address 有个什么区别?
  • 华为HCIE方向那么多应该如何选择?
  • CSS3学习教程,从入门到精通,CSS3 元素的浮动与定位语法知识点及案例代码(17)
  • mysql部署错误
  • ubuntu网络问题
  • 【蓝桥杯】4535勇闯魔堡(多源BFS + 二分)
  • HTML云原生:概念、技术与应用的全面解析
  • 基于QT(C++)实现用户界面系统
  • Pyecharts功能详解与实战示例
  • 从深度学习角度看线性代数
  • Kafka拦截器
  • .Net SSO 单点登录方式
  • </mirrorOf> Maven
  • 算法刷题--动态规划