码迷,mamicode.com
首页 > 其他好文 > 详细

【leetcode】Rotate List(middle)

时间:2015-03-11 21:24:58      阅读:114      评论:0      收藏:0      [点我收藏+]

标签:

Given a list, rotate the list to the right by k places, where k is non-negative.

For example:
Given 1->2->3->4->5->NULL and k = 2,
return 4->5->1->2->3->NULL.

 

题目关键点:k可能比链表长度还大, 需要获取链表长度len, 用 k % len 获取具体需要移动的数字。

class Solution {
public:
    ListNode *rotateRight(ListNode *head, int k) {
        if(head == NULL || head->next == NULL) return head;
        ListNode *f = head, *t = head;
        int len = 1;
        while(t != NULL && t->next != NULL)
        {
            len++;
            t = t->next;
        }

        int mv =len - k % len; //新的头结点在链表中的位置
        f = head; 
        while(--mv)
        {
            f = f->next;  //找到新的头结点的前一个结点
        }

        t->next = head; //尾巴连上最初的头结点
        ListNode * newhead = f->next;  //新的头结点
        f->next = NULL; //新的尾部

        return newhead;

    }
};

 

【leetcode】Rotate List(middle)

标签:

原文地址:http://www.cnblogs.com/dplearning/p/4330910.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!