Сторнирование LinkedList при сохранении оригинала - PullRequest
0 голосов
/ 05 февраля 2020

При попытке перевернуть связанный список ниже, у меня возникли проблемы с поиском способа сохранить исходный связанный список в случае, если я буду ссылаться 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;
    }
}
...