反转单链表 (三种方法整理)

原创 2015年10月26日 21:15:23

题目:反转单链表

输入一个链表,反转链表后,输出链表的所有元素。

据找工作的师兄说,反转单链表基本各个公司面试都会有,整理出一些写的比较好的code,供我等小白们学习。


方法一


  • 常规思路,简洁,清晰,我觉得写得蛮好的。

思路就是:从原链表的头部一个一个取节点并插入到新链表的头部
/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) :
            val(x), next(NULL) {
    }
};*/
class Solution {
public:
    ListNode* ReverseList(ListNode* pHead) {
        ListNode* newh = NULL;
        for(ListNode* p = pHead; p; )//p为工作指针
        {
            ListNode* tmp = p -> next;//temp保存下一个结点
            p -> next = newh;
            newh = p;
            p = tmp;
        }
        return newh;
    }
};


  • 这是我一开始写得,留着对比用,衬托,哈哈哈

思路一样,但是感觉没第一个写得简洁,但是我的绝对最好理解哈

class Solution {
public:
    ListNode* ReverseList(ListNode* pHead) {
        if(pHead == NULL)
            return pHead;      
        ListNode *res,*cur,*next;
        res = new ListNode(-1);
        cur = pHead;
        next = cur->next;
        while(cur != NULL)
            {       
            ListNode *first = res->next;
            cur->next = first;
            res->next = cur;

            cur = next;
            next = next->next;       
        }   
        return res->next;  
    }
};

方法二

思路:每次都将原第一个结点之后的那个结点放在新的表头后面。
比如1,2,3,4,5
第一次:把第一个结点1后边的结点2放到新表头后面,变成2,1,3,4,5
第二次:把第一个结点1后边的结点3放到新表头后面,变成3,2,1,4,5
……
直到: 第一个结点1,后边没有结点为止。
代码如下:

class Solution {
public:
    ListNode* ReverseList(ListNode* pHead) {
        if(pHead == NULL)
            return pHead;

        ListNode *res,*first,*temp;
        res = new ListNode(-1);
        res->next = pHead;

        first = res->next;       //first 始终为第一个结点,不断后移
        while(first->next!=NULL) //temp为待前差的
            {
            temp = first->next;
            first->next = temp->next;
            temp->next = res->next;
            res->next = temp;          
        }

        return res->next;
    }
};

方法三

第三种方法跟第二种方法差不多,第二种方法是将后面的结点向前移动到头结点的后面,第三种方法是将前面的结点移动到原来的最后一个结点的后面,思路跟第二种方法差不多,就不贴代码了。


还想整理一些写得好的,欢迎留言补充
未完待续。。。。。。。。。。。。。。。。。。。

单向链表反转(倒置)问题

今天遇到单向链表的反转的问题,于是静下心来好好想了一番。 解题思路如下图:假设当前创建好的链表如下:首先让头节点与第一个元素节点断开,但是要注意在断开之前需要用p指针指向第一个元素节点来保存第一个元...
  • blioo
  • blioo
  • 2017年03月14日 19:40
  • 7455

看图理解单链表的反转

如何把一个单链表进行反转? 方法1:将单链表储存为数组,然后按照数组的索引逆序进行反转。 方法2:使用3个指针遍历单链表,逐个链接点进行反转。 方法3:从第2个节点到第N个节点,依次逐节点插入到第1个...
  • feliciafay
  • feliciafay
  • 2011年10月02日 22:36
  • 49247

Java单链表反转 详细过程

Java单链表反转 Java实现单链表翻转 使用递归法实现单链表反转,使用遍历反转法:递归反转法是从后往前逆序反转指针域的指向,而遍历反转法是从前往后反转各个结点的指针域的指向。     【尊重原创,...
  • guyuealian
  • guyuealian
  • 2016年04月11日 10:36
  • 30515

反转单链表的几种方法

最近面试遇到了关于单项链表的问题 来一个最常见的题目:反转单链表。假设单链表的数据结构定义如下:    typedef struct LNode ...
  • chuyuqing
  • chuyuqing
  • 2015年03月19日 14:41
  • 7079

数据结构——反转单链表

最近看了《剑指offer》这本书,遇到了一个问题:反转链表 题目:定义一个函数,输入一个链表的头结点,反转该链表并输出反转后的链表的头结点。 链表结点定义如下:struct ListNode { ...
  • u013271921
  • u013271921
  • 2015年06月05日 22:17
  • 3146

链表反转

链表反转  1.链表有两种,一是带头结点的:头结点存储长度信息,头结点的next指向第一个实际节点;二是不带头结点的,头结点即第一个节点。这里使用带头结点的链表。  2.需要三个指针,记录当前节点...
  • forestLight
  • forestLight
  • 2011年09月29日 10:03
  • 12200

单链表反转/逆序的两种方法

摘自: http://www.nowamagic.net/librarys/veda/detail/2241 延伸阅读 此文章所在专题列表如下: 第01话:线性表的概念与定义第02话...
  • xiaojun111111
  • xiaojun111111
  • 2016年07月12日 15:54
  • 584

单链表实现反转的三种方法

单链表的操作是面试中经常会遇到的问题,今天总结一下反转的几种方案: 1 ,两两对换 2, 放入数组,倒置数组 3, 递归实现...
  • sinat_36899414
  • sinat_36899414
  • 2017年07月17日 20:03
  • 517

【面试题】-单链表反转

问题描述 将一个单链表反序输出,比如原单链表位1->2->3->4->NULL,反序输出后变为4->3->2->1->NULL 解题思路...
  • zwhlxl
  • zwhlxl
  • 2015年06月15日 22:29
  • 2001

【链表】C++链表反转、链表逆序打印

题目:C++实现链表逆序打印、链表反转 如何将链表逆序,取决于题目的要求。如果面试官只要求打印,一般不改动链表结构为好,如果要求改变链表的方向,则需要改变结构,再顺序打印。 方法1:只逆序打印,不改变...
  • yebanxin
  • yebanxin
  • 2016年07月18日 15:46
  • 4049
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:反转单链表 (三种方法整理)
举报原因:
原因补充:

(最多只允许输入30个字)