Самый простой способ думать об этом - думать следующим образом:
- Сначала добавьте заголовок списка в новый связанный список.
- Продолжайте перебирать оригинал ипродолжайте добавлять узлы перед заголовком нового связанного списка.
Диаграмма:
Изначально:
Original List -> 1 2 3 4 5
New List -> null
1-я итерация
Original List -> 1 2 3 4 5
New List -> 1->null [head shifted to left, now newHead contains 1 and points to null]
2-я итерация
Original List -> 1 2 3 4 5
New List -> 2-> 1->null [head shifted to left, now newHead contains 2 and points to next node which is 1]
3-я итерация
Original List -> 1 2 3 4 5
New List ->3 -> 2-> 1->null [head shifted to left, now newHead contains 2 and points to next node which is 1]
Теперь этопродолжает цикл до конца.Итак, наконец, новый список становится:
New List-> 5 -> 4 -> 3 -> 2 -> 1 -> null
Код для того же должен быть таким (это было легко понять):
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
public ListNode reverseList(ListNode head) {
if(head == null) {
return null;
}
if(head.next == null) {
return head;
}
ListNode current = head;
ListNode previous = new ListNode(head.val);
previous.next = null;
while(current.next != null) {
current = current.next;
previous = addBeforeHead(current, previous);
}
return previous;
}
private ListNode addBeforeHead(ListNode node, ListNode head) {
if (node == null) return null;
ListNode temp = new ListNode(node.val);
temp.next = head;
head = temp;
return head;
}