内容简介:Given a linked list, rotate the list to the right by k places, where k is non-negative.Example 1:Example 2:
Given a linked list, rotate the list to the right by k places, where k is non-negative.
Example 1:
Input: 1->2->3->4->5->NULL, k = 2 Output: 4->5->1->2->3->NULL Explanation: rotate 1 steps to the right: 5->1->2->3->4->NULL rotate 2 steps to the right: 4->5->1->2->3->NULL
Example 2:
Input: 0->1->2->NULL, k = 4 Output: 2->0->1->NULL Explanation: rotate 1 steps to the right: 2->0->1->NULL rotate 2 steps to the right: 1->2->0->NULL rotate 3 steps to the right: 0->1->2->NULL rotate 4 steps to the right: 2->0->1->NULL
难度:medium
题目:给定链表,向右旋转k个位置,k为非负整数。
思路:首先统计结点个数,并记录尾结点。然后用前后指针找出倒数第k + 1个结点。
Runtime: 7 ms, faster than 92.47% of Java online submissions for Rotate List.
Memory Usage: 27 MB, less than 41.82% of Java online submissions for Rotate List.
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode rotateRight(ListNode head, int k) {
if (null == head || k <= 0) {
return head;
}
int cnt = 0;
ListNode ptr = head,tail = ptr;
while (ptr != null) {
tail = ptr;
ptr = ptr.next;
cnt++;
}
k = k % cnt;
ListNode dummyHead = new ListNode(0), lastKPtr = dummyHead;
dummyHead.next = head;
ptr = dummyHead.next;
while (ptr != null) {
if (--k < 0) {
lastKPtr = lastKPtr.next;
}
ptr = ptr.next;
}
tail.next = dummyHead.next;
dummyHead.next = lastKPtr.next;
lastKPtr.next = null;
return dummyHead.next;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Developer's Guide to Social Programming
Mark D. Hawker / Addison-Wesley Professional / 2010-8-25 / USD 39.99
In The Developer's Guide to Social Programming, Mark Hawker shows developers how to build applications that integrate with the major social networking sites. Unlike competitive books that focus on a s......一起来看看 《Developer's Guide to Social Programming》 这本书的介绍吧!