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

相关推荐
haoly19893 小时前
数据结构和算法篇-线性查找优化-移至开头策略
数据结构·算法·移至开头策略
earthzhang20217 小时前
【1007】计算(a+b)×c的值
c语言·开发语言·数据结构·算法·青少年编程
冷徹 .11 小时前
2024ICPC区域赛香港站
数据结构·c++·算法
韧竹、12 小时前
数据结构之顺序表
c语言·数据结构
努力努力再努力wz16 小时前
【C++进阶系列】:万字详解智能指针(附模拟实现的源码)
java·linux·c语言·开发语言·数据结构·c++·python
敲代码的嘎仔16 小时前
JavaWeb零基础学习Day2——JS & Vue
java·开发语言·前端·javascript·数据结构·学习·算法
yacolex17 小时前
3.3_数据结构和算法复习-栈
数据结构·算法
cookqq18 小时前
MongoDB源码delete分析oplog:从删除链路到核心函数实现
数据结构·数据库·sql·mongodb·nosql
ʚ希希ɞ ྀ18 小时前
用队列实现栈---超全详细解
java·开发语言·数据结构
要一起看日出18 小时前
数据结构-----栈&队列
java·数据结构··队列