При попытке перевернуть связанный список ниже, у меня возникли проблемы с поиском способа сохранить исходный связанный список в случае, если я буду ссылаться sh после обращения. Само обращение работает для всех случаев. Если я обращаюсь к голове после обращения, я получаю только первый элемент, как и ожидалось, так как это «хвост» нового списка. Существует ли эффективный способ сохранить копию оригинала, чтобы после возврата выходных данных заголовок / какой-либо другой объект ссылался на заголовок введенного списка в порядке? Я видел несколько других сообщений об этой идее, но не этот конкретный c сценарий.
Спасибо!
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode reverseList(ListNode head) {
if (head == null) {return head;}
ListNode prev = null;
ListNode curr = head;
ListNode next = null;
while (curr != null) {
next = curr.next;
curr.next = prev;
prev = curr;
curr = next;
}
return prev;
}
}