P61 旋转链表

刚看第一眼,感觉把它变成循环链表然后直接移动头节点k个位置,输出链表长度就可以。

Screenshot 2025-11-11 112440.png

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* rotateRight(ListNode* head, int k) {
        if (head == nullptr || head->next == nullptr || k == 0) {
            return head;
        }
        ListNode* p = head;
        int len = 1;
        while (p->next != nullptr) {
            p = p->next;
            len++;
        }
        p->next = head;
        int realStep = len - (k % len);
        for (int i = 0; i < realStep; i++) {
            p = p->next; 
        }
        ListNode* newHead = p->next; 
        p->next = nullptr;
​
        return newHead;
    }
};

Screenshot 2025-11-11 112453.png

看来和我的想法一样,链接成环,再创建新链表。

总是感觉自己是错的哈哈, 每次都感觉会不会有更好的方法

大家一定自信一点 ,拜拜!(* ̄3 ̄)╭

迷茫java练习生