【leetcode】61. Rotate List

题目说明

https://leetcode-cn.com/problems/rotate-list/description/
给定一个链表,旋转链表,将链表每个节点向右移动 k 个位置,其中 k 是非负数。

解法1

/*
 * 时间复杂度:O(n)
 * 得到链表长度,k对其取余(对链表进行旋转次数是长度的整数倍数时,链表是不变的),求得的k值即有效的旋转次数
 * 每次旋转,将最后一个结点移到第一个结点位置
 * 所以每次都需要定位到最后一个结点前一个结点的位置,方便进行移动操作
 */
ListNode* rotateRight(ListNode* head, int k) {
    ListNode *dummy = new ListNode(0);
    dummy->next = head;

    ListNode *pre = dummy->next;
    ListNode *cur = NULL;

    if (pre == NULL || pre->next == NULL)
        return head;

    int len = 1;
    while(pre->next){
        pre=pre->next;
        len ++;
    }

    k = k % len;

    for (int i = 0; i < k; i ++){
        pre = dummy->next;
        while(pre->next->next)
            pre = pre->next;
        cur = pre->next;
        pre->next = cur->next;
        cur->next = dummy->next;
        dummy->next = cur;
    }
    return dummy->next;
}

解法2

/*
 * 时间复杂度:O(n)
 * 使用双指针,获取到需要旋转的区间,然后整体旋转到头部
 */
ListNode* rotateRight(ListNode* head, int k) {
    ListNode *dummy = new ListNode(0);
    dummy->next = head;

    ListNode *pre = dummy->next;
    ListNode *cur = NULL;
    ListNode *next = NULL;

    if (pre == NULL || pre->next == NULL)
        return head;

    int len = 1;
    while(pre->next){
        pre=pre->next;
        len ++;
    }

    k = k % len;
    if (k == 0)
	return head;
    ListNode *start = dummy->next;
    ListNode *end =  dummy->next;

    for (int i = 0; i < k; i ++){
        end = end->next;
    }

    while(end->next){
        start = start->next;
        end = end->next;
    }

    next = dummy->next;
    dummy->next = start->next;
    end->next = next;
    start->next = NULL;

    return dummy->next;
}
posted @ 2018-09-05 23:24  JESSET  阅读(132)  评论(0编辑  收藏  举报