链表专项练习题一 | 反转单链表的算法实现


题目

定义一个函数,输入一个链表的头结点,反转该链表并输出反转后链表的头结点。
下面给出链表定义:

struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) :
            val(x), next(NULL) {
    }
};

分析

题目描述有三个关键点:

  1. 输入头结点
  2. 反转链表
  3. 输出反转后的头结点

其中,最核心的是【反转链表】
链表反转示意图
反转链表的关键点:

  1. 保存要修改结点的下一结点
  2. 保存要修改结点的上一结点
  3. 最后修改结点指向
  4. 注意“断链”问题,注意首尾节点问题

算法实现

ListNode* ReverseList(ListNode* pHead)
{
    ListNode* pReversedHead = NULL;
    ListNode* pNode = pHead;
    ListNode* pPrev = NULL;
    while(pNode != NULL)
    {
        ListNode* pNext = pNode->m_pNext;

        if(pNext == NULL)
            pReversedHead = pNode;

        pNode->m_pNext = pPrev;

        pPrev = pNode;
        pNode = pNext;
    }

    return pReversedHead;
}

本文发表于2018年11月06日 21:01
阅读 4708 讨论 0 喜欢 2

抢先体验

扫码体验
趣味小程序
文字表情生成器

闪念胶囊

万稳万当,不如一默。任何一句话,你不说出来便是那句话的主人,你说了出来,便是那句话的奴隶。

你要过得好哇,这样我才能恨你啊,你要是过得不好,我都不知道该恨你还是拥抱你啊。

直抵黄龙府,与诸君痛饮尔。

那时陪伴我的人啊,你们如今在何方。

不出意外的话,我们再也不会见了,祝你前程似锦。

快捷链接
网站地图
提交友链
Copyright © 2016 - 2021 Cion.
All Rights Reserved.
京ICP备2021004668号-1