最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
Java语言实现反转链表代码示例
时间:2022-06-29 01:12:38 编辑:袖梨 来源:一聚教程网
问题描述
定义一个函数,输入一个链表的头结点,反转该链表并输出反转后的链表的头结点。链表结点如下:
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:
使用递归的思想(暂时没有想到,因为如果用递归的话,每次应该是:链表的第一个结点<—递归返回的链表的尾指针,但是这样的话就无法获得反转后的头指针了。)后面再思考吧。
相关文章
- 差差漫画登录首页-差差漫画在线登录免费弹窗 02-06
- 抖音网页版入口-官方电脑版登录免费教程2026 02-06
- 差差漫画官方最新版本下载安装入口-差差漫画免费高清漫画页面在线观看 02-06
- 百度地图如何打开全景模式-百度地图全景开启方法 02-06
- poki游戏官网正版入口-poki游戏正版安全无忧官网 02-06
- picacg游咔-官网最新入口2026 02-06