数据结构每日一题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)

相关推荐
LuminousCPP11 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
AI算法沐枫11 小时前
深度学习python代码处理科研测序数据
数据结构·人工智能·python·深度学习·决策树·机器学习·线性回归
m0_6294947313 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户13 小时前
用队列实现栈
数据结构·算法
欧米欧15 小时前
C++进阶数据结构之搜索二叉树
开发语言·数据结构·c++
小江的记录本15 小时前
【Java基础】反射与注解:核心原理、自定义注解、注解解析方式(附《思维导图》+《面试高频考点清单》)
java·数据结构·python·mysql·spring·面试·maven
Trouvaille ~16 小时前
【Redis篇】初识 Redis:特性、应用场景与版本演进
数据结构·数据库·redis·分布式·缓存·中间件·持久化
向日的葵00617 小时前
从IO视角深度对比:BST、红黑树、B树、B+树
数据结构·b树
小羊在睡觉18 小时前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go
我星期八休息18 小时前
Linux系统编程—库制作与原理
linux·运维·服务器·数据结构·人工智能·python·散列表