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

相关推荐
John.Lewis2 分钟前
数据结构初阶(11)排序的概念与运用
c语言·数据结构·排序算法
FPGA1 小时前
曼彻斯特编解码:数字世界的“摩斯密码”与FPGA高效实现
数据结构
数据智能老司机1 小时前
图算法趣味学——图遍历
数据结构·算法·云计算
Gu_shiwww2 小时前
数据结构3线性表——单链表(C)
c语言·开发语言·数据结构
科大饭桶3 小时前
Linux系统编程Day13 -- 程序地址空间(进阶)
linux·运维·c语言·数据结构·c++
C_Liu_4 小时前
C语言:队列的实现和剖析
c语言·开发语言·数据结构
定偶4 小时前
Notepad++插件开发实战
开发语言·数据结构·notepad++
屁股割了还要学9 小时前
【数据结构入门】堆
c语言·开发语言·数据结构·c++·考研·算法·链表
源代码•宸12 小时前
MySQL 索引:索引为什么使用 B+树?(详解B树、B+树)
数据结构·数据库·经验分享·b树·mysql·b+树·b-树
数据智能老司机20 小时前
图算法趣味学——最大流算法
数据结构·算法·云计算