题目描述:
输入一个链表,反转链表后,输出新链表的表头。
解题思路:
使用头插法来反转链表,每次将新的节点插入到反转后链表的头部,原始链表遍历完就可以实现链表反转。
代码(java):
/*
public class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}*/
public class Solution {
public ListNode ReverseList(ListNode head) {
if(head==null)return head;
ListNode next=null;
ListNode pre=null;
while(head!=null){
next=head.next;
head.next=pre;
pre=head;
head=next;
}
return pre;
}
}