您的位置:首页 > 其它

反转链表

2017-01-14 21:17 190 查看


题目描述

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

数据结构:

/*
public class ListNode {
int val;
ListNode next = null;

ListNode(int val) {
this.val = val;
}
}*/

注意事项:

输入链表头指针为空,或者整个链表只有一个结点的时候,程序是否会崩溃。

反转后的链表出现断裂。

返回的反转之后的头结点不是原来的尾结点。

解法:

从头到尾遍历所有结点,利用头插法将整个链表反转。

代码如下:

public ListNode ReverseList(ListNode head) {
if (head == null){
return null;
}

ListNode pre = null;
ListNode next = null;
while(head !=null){
next = head.next;
head.next = pre;
pre = head;
head = next;
}
return pre;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: