将链表L就地逆置,即利用原表各结点的空间实现逆置

一、题目

将链表L就地逆置,即利用原表各结点的空间实现逆置。

二、思路

在链表的第二个元素开始执行逆置,因为如果链表只有一个元素,那么逆置就没有意义了。

步骤:

  • 假设原链表如下:


    原链表@author H_JJia
  • 将结点1的指针指向结点3,也就是说将结点2脱离链表:


    将结点1的指针指向结点3

    此时结点2脱离链表,变成游离态@author H_JJia
  • 将L链表的头结点指针指向结点2,然后结点2变成第一个元素,结点2的指针指向结点1,此刻实现了第一个逆置。


    头结点指针指向结点2,结点2的指针指向结点1@author H_JJia

    实现了第一个倒置@author H_JJia
  • 重复上述2、 3步,将结点3脱离链表,然后就可以接到头结点之后,变成第一个元素。


    结点3接到头结点之后@author H_JJia

    这里写图片描述@author H_JJia
  • 结点4依旧是重复步骤2 、 3,将结点4接到头结点之后;


    @author H_JJia

    @author H_JJia
  • 重复循环,就可以将结点元素实现逆置了。具体代码见下:

四、具体代码

    /*
     * 逆置链表L
     */
    public void convert_List(Node L){
        Node p,t;
        p=L.next;               //此时指针p指向链表L的第一个结点
        while(p.next!=null){    //第二个结点不为空,因为逆置,需要链表有两个及以上的元素逆置才有意义
            t=p.next;
            p.next=t.next;      //此时跳过了t结点元素,也就是说t结点元素脱离了链表
            t.next=L.next;      //将t结点元素放在头结点后面,即t结点元素成为第一个结点
            L.next=t;           //头结点的指针指向t
        }
    }

五、总结

  • t=p.next; p.next=t.next; t.next=L.next; L.next=t;
    这几步看着会非常晕的,但是如果照着图看,或者自己画画图,就能够很容易理解了。

  • while(p.next!=null)
    原先p已经指向第一个结点,现在p.next!=null 表示需要第二个结点不为空,链表逆置从第二个元素开始。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 链表是线性表的链式存储方式,逻辑上相邻的数据在计算机内的存储位置不一定相邻,那么怎么表示逻辑上的相邻关系呢? 可以...
    rainchxy阅读 2,047评论 0 6
  • 大学的时候不好好学习,老师在讲台上讲课,自己在以为老师看不到的座位看小说,现在用到了老师讲的知识,只能自己看书查资...
    和珏猫阅读 1,484评论 1 3
  • 本文内容取自于小甲鱼的数据结构与算法。//www.greatytc.com/p/230e6fde9c75 ...
    阿阿阿阿毛阅读 2,941评论 0 7
  • B树的定义 一棵m阶的B树满足下列条件: 树中每个结点至多有m个孩子。 除根结点和叶子结点外,其它每个结点至少有m...
    文档随手记阅读 13,379评论 0 25
  • 1.线性表的定义 线性表:零个或多个数据元素的有限序列序列:也就是说元素之间是有顺序的,若元素存在多个,则第一个元...
    e40c669177be阅读 2,099评论 6 15