成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

LeetCode 189: Rotate Array (Java)

Airmusic / 555人閱讀

摘要:解法一假設數(shù)組為先把換到的位置,把拿著換到的位置,把拿著換到的位置。。。停止條件姑且假設為當置換的數(shù)回到數(shù)組的首位。不過換一個栗子上述方法就不通了,比如數(shù)組為換一輪發(fā)現(xiàn)結果是。

題目: Rotate an array of n elements to the right by k steps.

For example, with n = 7 and k = 3, the array [1,2,3,4,5,6,7] is rotated to [5,6,7,1,2,3,4].

兩種解法:

第一種是原地swap,記錄下被擠掉的數(shù)再接著swap,需要一些時間舉栗子探索規(guī)律;

第二種是倒三次的方法,如果之前沒有準備過,面試中不太可能自己想出來。

解法一(12%):

假設數(shù)組為[1,3,5,7,9], k = 2 :
先把1換到5的位置,把5拿著換到9的位置,把9拿著換到3的位置。。。最后7到了1的位置就換完了,貌似計劃通啊。
停止條件姑且假設為當置換的數(shù)回到數(shù)組的首位。
不過換一個栗子上述方法就不通了,比如數(shù)組為[1,3,5,7,9,11], k = 2, 換一輪發(fā)現(xiàn)結果是[9,3,1,7,5,11]。
這里要從3開始重復一遍上述方法,所以要再套一個loop,i = 0, 停止條件為 最大公約數(shù)(數(shù)組長度,k)。這樣所有的情況都能cover了。

public static void rotate(int[] nums, int k) {
    if(nums == null || nums.length <= 1)
        return;
    k = k%nums.length;

    int prev = 0;
    int next = 0;
    int maxComm = maxCommonDivisor(k,nums.length);
    for(int i = 0; i < maxComm;i++){

        prev = nums[i];
        int j = i+k;
        j %= nums.length;
        while(j != i){
            next = nums[j];
            nums[j] = prev;
            prev = next;
            j+=k;
            j%=nums.length;
        }
        nums[j] = prev;
    }
    return;
}

private static int maxCommonDivisor(int m, int n){
    while (m % n != 0) {
        int temp = m % n;
        m = n;
        n = temp;
    }
    return n;
}
解法二(12%):

巧妙的reverse三次:
第一次reverse整個數(shù)組;
第二次reverse子數(shù)組(0,k-1);
第三次reverse子數(shù)組(k,length-1)

reverse的函數(shù)都是一樣的,所以可以寫一個helper。

public static void rotate(int[] nums,int k) {
    if(nums == null || nums.length <= 1)
        return;
    k %=nums.length;
    if(k == 0)
        return;
    helper(nums,0,nums.length-1);
    helper(nums,0,k-1);
    helper(nums,k,nums.length-1);
}

public static void helper(int[] nums,int start,int end) {
    for(int i = start; i <= (end+start)/2;i++) {
        int temp = nums[end+start-i];
        nums[end+start-i] = nums[i];
        nums[i] = temp;
    }
}

最后貼一下最快的code(98%):

public void rotate(int[] nums, int k) {
        int n = nums.length;
        k = k%n;
        int[] temp = Arrays.copyOfRange(nums, 0, n-k);
        System.arraycopy(nums, n-k, nums, 0, k);
        System.arraycopy(temp, 0, nums, k, n-k);
    }
    
    

Reference: 0ms 5-line java

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/66064.html

相關文章

  • LeetCode 189:旋轉(zhuǎn)數(shù)組 Rotate Array

    摘要:公眾號愛寫給定一個數(shù)組,將數(shù)組中的元素向右移動個位置,其中是非負數(shù)。只要截取輸入的后位的數(shù)組與輸入的剩余長度的數(shù)組,即為所求但是題目要求使用空間復雜度為的原地算法。利用切片切片組成新數(shù)組 公眾號:愛寫bug(ID:icodebugs) 給定一個數(shù)組,將數(shù)組中的元素向右移動 k 個位置,其中 k 是非負數(shù)。 Given an array, rotate the array to the ...

    cnsworder 評論0 收藏0
  • LeetCode 189:旋轉(zhuǎn)數(shù)組 Rotate Array

    摘要:公眾號愛寫給定一個數(shù)組,將數(shù)組中的元素向右移動個位置,其中是非負數(shù)。只要截取輸入的后位的數(shù)組與輸入的剩余長度的數(shù)組,即為所求但是題目要求使用空間復雜度為的原地算法。利用切片切片組成新數(shù)組 公眾號:愛寫bug(ID:icodebugs) 給定一個數(shù)組,將數(shù)組中的元素向右移動 k 個位置,其中 k 是非負數(shù)。 Given an array, rotate the array to the ...

    zhangrxiang 評論0 收藏0
  • LeetCode 189.Rotate Array

    摘要:問題描述解題思路使用數(shù)組自帶的方法和方法把數(shù)組最后一個取出來加入到頭部。使用數(shù)組的方法得到后個數(shù),再用方法刪去后個數(shù),最后用方法把得到的后個數(shù)添加到數(shù)組前面。 問題描述: 189.Rotate Array Rotate an array of n elements to the right by k steps. For example, with n = 7 and k = 3, t...

    leanote 評論0 收藏0
  • LeetCode 61:旋轉(zhuǎn)鏈表 Rotate List

    摘要:給定一個鏈表,旋轉(zhuǎn)鏈表,將鏈表每個節(jié)點向右移動個位置,其中是非負數(shù)。按上述思路解,與旋轉(zhuǎn)數(shù)組那道題大同小異,來介紹另一種很簡單高效的方法。只需在第個節(jié)點之后切斷,首尾連接即可。另外可能大于鏈表長度,應當做求余運算。 ?給定一個鏈表,旋轉(zhuǎn)鏈表,將鏈表每個節(jié)點向右移動 k 個位置,其中 k 是非負數(shù)。 Given a linked list, rotate the list to the ...

    Hwg 評論0 收藏0
  • leetcode部分題目答案之JavaScript版

    摘要:自己沒事刷的一些的題目,若有更好的解法,希望能夠一起探討項目地址 自己沒事刷的一些LeetCode的題目,若有更好的解法,希望能夠一起探討 Number Problem Solution Difficulty 204 Count Primes JavaScript Easy 202 Happy Number JavaScript Easy 190 Reverse Bi...

    alphahans 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<