1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
| package com.demo.s61;
class ListNode { int val; ListNode next; ListNode() {} ListNode(int val) { this.val = val; } ListNode(int val, ListNode next) { this.val = val; this.next = next; } } public class Solution { public ListNode rotateRight(ListNode head, int k) { if(head == null) { return null; } ListNode cur = head; int n = 1; while(cur.next != null) { cur = cur.next; n++; } int y = n - k % n; if(y == n) { return head; } cur.next = head; while(y -- > 0) { cur = cur.next; } head = cur.next; cur.next = null; return head; } }
|