【山大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.运行结果

相关推荐
Not Dr.Wang42230 分钟前
自动控制系统稳定性研究及判据分析
算法
VT.馒头30 分钟前
【力扣】2722. 根据 ID 合并两个数组
javascript·算法·leetcode·职场和发展·typescript
ffqws_35 分钟前
A*算法:P5507 机关 题解
算法
执着2591 小时前
力扣hot100 - 108、将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
2501_901147831 小时前
学习笔记:单调递增数字求解的迭代优化与工程实践
linux·服务器·笔记·学习·算法
AI科技星1 小时前
张祥前统一场论核心场方程的经典验证-基于电子与质子的求导溯源及力的精确计算
线性代数·算法·机器学习·矩阵·概率论
kebijuelun1 小时前
ERNIE 5.0:统一自回归多模态与弹性训练
人工智能·算法·语言模型·transformer
历程里程碑1 小时前
普通数组----最大子数组和
大数据·算法·elasticsearch·搜索引擎·排序算法·哈希算法·散列表
52Hz1182 小时前
力扣230.二叉搜索树中第k小的元素、199.二叉树的右视图、114.二叉树展开为链表
python·算法·leetcode
苦藤新鸡2 小时前
56.组合总数
数据结构·算法·leetcode