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

資訊專(zhuān)欄INFORMATION COLUMN

leetcode60. Permutation Sequence

xiaokai / 3078人閱讀

摘要:題目要求假設(shè)按照題中給的排列組合的順序,假設(shè)有個(gè)數(shù)字,返回第個(gè)排列組合的結(jié)果。最后在個(gè)位上,選擇中的第一個(gè)。這時(shí)知道以第位為開(kāi)頭的結(jié)果值有此時(shí)第個(gè)結(jié)果集在該位上的選擇為。依次往后類(lèi)推,直至到最后一位。

題目要求
The set [1,2,3,…,n] contains a total of n! unique permutations.

By listing and labeling all of the permutations in order,
We get the following sequence (ie, for n = 3):

1."123"
2."132"
3."213"
4."231"
5."312"
6."321"
Given n and k, return the kth permutation sequence.

Note: Given n will be between 1 and 9 inclusive.

假設(shè)按照題中給的排列組合的順序,假設(shè)有1~n個(gè)數(shù)字,返回第k個(gè)排列組合的結(jié)果。

思路與代碼

首先來(lái)整理一下思路。如果有n個(gè)數(shù)組,則能排列組合出n!個(gè)結(jié)果。然后再按照排列組合結(jié)果的各個(gè)位上的數(shù)字選擇來(lái)分析。這里舉一個(gè)具體的例子。就看題中給的例子,此時(shí)n=3。假設(shè)k=5。則在百位上,選擇的數(shù)字為[1,2,3]中的第三個(gè),這是再看十位上的數(shù)字,選擇了[1,2]中的第一個(gè)數(shù)。最后在個(gè)位上,選擇[1]中的第一個(gè)。
可以總結(jié)出,假設(shè)輸入n,k,則結(jié)果上的從左往右第1位上的數(shù)字為結(jié)果集中第(k-1)/(n-1)!個(gè)數(shù)字。這時(shí)知道以第1位為開(kāi)頭的結(jié)果值有(n-1)!,此時(shí)第k個(gè)結(jié)果集在該位上的選擇為k%factorial[n-1]。依次往后類(lèi)推,直至到最后一位。代碼如下:

    public String getPermutation(int n, int k) {
        //factorial
        int[] factorial = new int[]{1,1,2,6,24,120,720,5040,40320,362880};
        
        //初始化
        List numbers = new LinkedList();
        for(int i = 0 ; i


想要了解更多開(kāi)發(fā)技術(shù),面試教程以及互聯(lián)網(wǎng)公司內(nèi)推,歡迎關(guān)注我的微信公眾號(hào)!將會(huì)不定期的發(fā)放福利哦~

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

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

相關(guān)文章

  • [Leetcode] Permutation Sequence 全排列序列

    摘要:找規(guī)律復(fù)雜度時(shí)間空間思路由于我們只要得到第個(gè)全排列,而不是所有全排列,我們不一定要將所有可能都搜索一遍。根據(jù)全排列順序的性質(zhì),我們可以總結(jié)出一個(gè)規(guī)律假設(shè)全排列有個(gè)數(shù)組成,則第個(gè)全排列的第一位是。然后將得到,這個(gè)就是下一輪的。 Permutation Sequence The set [1,2,3,…,n] contains a total of n! unique permutati...

    testHs 評(píng)論0 收藏0
  • leetcode78. Subsets

    摘要:題目要求類(lèi)似的題目有可以參考這篇博客可以參考這篇博客思路一遞歸還是利用遞歸的方式,在前一種情況的基礎(chǔ)上遍歷下一輪的組合情況。 題目要求 Given a set of distinct integers, nums, return all possible subsets. Note: The solution set must not contain duplicate subset...

    Rocko 評(píng)論0 收藏0
  • [LeetCode] 953. Verifying an Alien Dictionary

    Problem In an alien language, surprisingly they also use english lowercase letters, but possibly in a different order. The order of the alphabet is some permutation of lowercase letters. Given a seque...

    ghnor 評(píng)論0 收藏0
  • [LintCode] Permutation Sequence

    摘要:做法先把這個(gè)數(shù)放入一個(gè)數(shù)組里,同時(shí)計(jì)算出的階乘。假設(shè)這一組是第組,第一個(gè)數(shù)就是,同時(shí)刪去這個(gè)數(shù),并讓除以取余作為新的。如此循環(huán),這樣,下一組的成員數(shù)減少了,要找的位置也更為精確了。 Problem Given n and k, return the k-th permutation sequence. Example For n = 3, all permutations are li...

    Jacendfeng 評(píng)論0 收藏0
  • [Leetcode] Palindrome Permutation 回文變換

    摘要:最笨的方法就是用的解法,找出所有的,然后再用中判斷回文的方法來(lái)判斷結(jié)果中是否有回文。而中心對(duì)稱(chēng)點(diǎn)如果是字符,該字符會(huì)是奇數(shù)次,如果在兩個(gè)字符之間,則所有字符都是出現(xiàn)偶數(shù)次。 Palindrome Permutation Given a string, determine if a permutation of the string could form a palindrome. F...

    svtter 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<