java语言实现反转链表 Java语言实现反转链表代码示例

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

java语言实现反转链表 Java语言实现反转链表代码示例

lilivian   2021-03-29 我要评论
想了解Java语言实现反转链表代码示例的相关内容吗,lilivian在本文为您仔细讲解java语言实现反转链表的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:java,反转,链表,下面大家一起来学习吧。

问题描述

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

public class ListNode {
  int val;
  ListNode next = null;
  ListNode(int val) {
    this.val = val;
  }
}

思路1:

要想反转链表,对于结点i,我们要把它的next指向它的前趋,因此我们需要保存前趋结点,同时,如果我们已经把i的next重新赋值,会无法找到i的后继,因此,在重新赋值之前,我们要保存i的后继。

代码:

public ListNode ReverseList(ListNode head) {
    if(head == null){
      return null;
    }
    ListNode rHead = null;
    ListNode prior = null;//store prior
    ListNode q = head;//store current
    while(q != null){
      ListNode next = q.next;//store the next
      if(next == null){
        rHead = q;
      }
      q.next = prior;
      prior = q;
      q = next;
    }
    return rHead;
  }

思路2:

使用递归的思想(暂时没有想到,因为如果用递归的话,每次应该是:链表的第一个结点<—递归返回的链表的尾指针,但是这样的话就无法获得反转后的头指针了。)后面再思考吧。

总结

以上就是本文关于Java语言实现反转链表代码示例的全部内容,感兴趣的朋友可以参阅:Java编程删除链表中重复的节点问题解决思路及源码分享Java编程实现从尾到头打印链表代码实例以及本站其他相关专题,希望对大家有所帮助。如有不足之处,欢迎留言指出。

猜您喜欢

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们