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

資訊專欄INFORMATION COLUMN

31. Next Permutation

未東興 / 414人閱讀

摘要:邊界條件,這時候之后只有一個值數(shù)組一直遞減,這時候變成,沒有,只需要從到的所有數(shù)。

31. Next Permutation

題目鏈接:https://leetcode.com/problems...

這道題就是找規(guī)律,可以看出來下一個permutation的規(guī)律是:從右往左掃,找到第一個滿足:nums[i-1] < nums[i]條件的,再找到從右到左第一個比nums[i-1]大的數(shù),把它們swap,再把所有i-1之后的數(shù)字swap即可。邊界條件:1. i = nums.length - 1,這時候i-1之后只有一個值, 2. 數(shù)組一直遞減,這時候i變成0,沒有nums[i-1]swap,只需要swap從0到nums.length - 1的所有數(shù)。

public class Solution {
    public void nextPermutation(int[] nums) {
        int i = nums.length - 1;
        while(i > 0) {
            if(nums[i-1] < nums[i]) break;
            i--;
        }
        // i = 0, decreasing
        if(i != 0) {
            int j = nums.length - 1;
            while(j >= 0) {
                if(nums[j] > nums[i-1]) break;
                j--;
            }
            swap(nums, i-1, j);
        }
        
        // swap all elements after i-1
        int end = nums.length - 1;
        while(i < end) swap(nums, i++, end--);
    }
    
    private void swap(int[] nums, int i, int j) {
        int temp = nums[i];
        nums[i] = nums[j];
        nums[j] = temp;
    }
}

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

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

相關(guān)文章

  • leetcode 31 Next Permutation

    摘要:我們所找到的這個元素就是排序需要改變的第一個元素。然后我們選取一個剛好大于此元素的數(shù),與當前元素進行替換。并對后面的所有元素重新按照升序排列就可以得到最終的答案。 題目詳情 Implement next permutation, which rearranges numbers into the lexicographically next greater permutation of...

    binaryTree 評論0 收藏0
  • leetcode31 Next Permutation

    摘要:如果當前數(shù)字代表的整數(shù)值已經(jīng)是所有排列組合中的最大值,則返回當前數(shù)字組成的最小值。可是這意味著大量無用的數(shù)字的生成和比較。一個數(shù)字中的各個位上的數(shù)如何調(diào)整順序才能獲得一個最小的更大值。其次,要保證移動之后,高位以后的值為最小值。 題目要求 Implement next permutation, which rearranges numbers into the lexicographi...

    hedzr 評論0 收藏0
  • 31. Next Permutation

    摘要:比如我們很容易知道下一個數(shù)字是。從尾到頭找,第一段的部分出現(xiàn)。后面的部分就可以有更大的組合。這里是在遞減序列中找到下一個比大的數(shù)字,作為序列的頭。尾部的遞減序列變成遞增序列。 Implement next permutation, which rearranges numbers into the lexicographically next greater permutation o...

    denson 評論0 收藏0
  • [LintCode] Next Permutation II [Next Permutation]

    摘要:從末位向前遍歷,假設(shè)循環(huán)開始全是倒序排列,如當?shù)谝淮纬霈F(xiàn)正序的時候,如的和此時從數(shù)列末尾向前循環(huán)到,找到第一個比大的交換這兩個數(shù),變成倒置第位到末位的數(shù)為正序排列這里的是完全倒置的排列,如,即上面循環(huán)的情況完全沒有出現(xiàn), Problem Implement next permutation, which rearranges numbers into the lexicographic...

    mikasa 評論0 收藏0
  • [Leetcode] Next Permutation 下一個排列

    摘要:因為增加高位會帶來更大的增益。所以對于一個長為的序列,我們增加第位的前提是,前位已經(jīng)達到了最大排列方法。因為是找下一個數(shù),所以我們要找一個比小卻盡可能大的數(shù),所以找到。把換到的位置后,后三位仍然是個降序的排列。 Next Permutation Implement next permutation, which rearranges numbers into the lexicogr...

    young.li 評論0 收藏0

發(fā)表評論

0條評論

閱讀需要支付1元查看
<