【山大909算法题】2014-T1

文章目录

1.原题

为带表头的单链表类Chain编写一个成员函数Reverse,该函数对链表进行逆序操作(将链表中的结点按与原序相反的顺序连接),要求逆序操作就地进行,不分配任何新的结点。要求首先给出类的声明,在类的声明中,其它成员函数省略。

2.算法思想

定义三个指针变量,*prevNode、*currentNode、*nextNode,在遍历过程中反指。对第一个元素和最后一个的元素处理略有不同,需要单独处理。

3.关键代码

c 复制代码
/**
 * @struct ListNode
 * @brief 单链表中的节点结构。
 */
struct ListNode {
    int data; /**< 节点中存储的数据 */
    struct ListNode *next; /**< 指向下一个节点的指针 */
};

/**
 * @struct List
 * @brief 单链表结构。
 */
struct List {
    struct ListNode *head; /**< 指向链表头节点的指针 */
    int size; /**< 链表的大小 */
};

/**
 * @brief 反转链表中的元素。
 * @param list 指向 List 结构的指针。
 */
void Reverse(struct List *list) {
    struct ListNode *prevNode = NULL, *currentNode = list->head->next, *nextNode = NULL;

    while (currentNode != NULL) {
        nextNode = currentNode->next; // 存储下一个节点
        currentNode->next = prevNode; // 反转指向前一个节点的指针
        prevNode = currentNode; // 移动指针以进行下一次迭代
        currentNode = nextNode;
    }

    list->head->next = prevNode; // 更新头指针,使其指向反转后的新的第一个节点
}

4.完整代码

c 复制代码
#include <stdio.h>
#include <stdlib.h>

/**
 * @struct ListNode
 * @brief 单链表中的节点结构。
 */
struct ListNode {
    int data; /**< 节点中存储的数据 */
    struct ListNode *next; /**< 指向下一个节点的指针 */
};

/**
 * @struct List
 * @brief 单链表结构。
 */
struct List {
    struct ListNode *head; /**< 指向链表头节点的指针 */
    int size; /**< 链表的大小 */
};

/**
 * @brief 反转链表中的元素。
 * @param list 指向 List 结构的指针。
 */
void Reverse(struct List *list) {
    struct ListNode *prevNode = NULL, *currentNode = list->head->next, *nextNode = NULL;

    while (currentNode != NULL) {
        nextNode = currentNode->next; // 存储下一个节点
        currentNode->next = prevNode; // 反转指向前一个节点的指针
        prevNode = currentNode; // 移动指针以进行下一次迭代
        currentNode = nextNode;
    }

    list->head->next = prevNode; // 更新头指针,使其指向反转后的新的第一个节点
}

/**
 * @brief 显示链表中的元素。
 * @param list 指向 List 结构的指针。
 */
void displayList(struct List *list) {
    struct ListNode *currentNode = list->head->next;

    printf("head");
    while (currentNode != NULL) {
        printf("->%d", currentNode->data);
        currentNode = currentNode->next;
    }
    printf("->NULL\n");
}


int main() {
    struct List list;
    list.head = (struct ListNode *) malloc(sizeof(struct ListNode));
    list.head->next = NULL;
    list.size = 0;

    // 插入初始元素 1, 2, 3, 4, 5
    for (int i = 1; i <= 5; ++i) {
        struct ListNode *newNode = (struct ListNode *) malloc(sizeof(struct ListNode));
        newNode->data = i;
        newNode->next = list.head->next;
        list.head->next = newNode;
        list.size++;
    }

    // 输出原始链表
    printf("Original List: ");
    displayList(&list);

    // 执行反转操作
    Reverse(&list);

    // 输出反转后的链表
    printf("Reversed List: ");
    displayList(&list);

    return 0;
}

5.运行结果

相关推荐
IronMurphy2 小时前
【算法四十三】279. 完全平方数
算法
墨染天姬2 小时前
【AI】Hermes的GEPA算法
人工智能·算法
papership2 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826522 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
Beginner x_u3 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
_深海凉_6 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
旖-旎7 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰7 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx7 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer7 小时前
【无标题】
开发语言·c++·算法