摘要:找規律復雜度時間空間思路由于我們只要得到第個全排列,而不是所有全排列,我們不一定要將所有可能都搜索一遍。根據全排列順序的性質,我們可以總結出一個規律假設全排列有個數組成,則第個全排列的第一位是。然后將得到,這個就是下一輪的。
Permutation Sequence
找規律 復雜度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):
"123" "132" "213" "231" "312" "321" Given n and k, return the kth permutation sequence.
Note: Given n will be between 1 and 9 inclusive.
時間 O(N) 空間 O(1)
思路由于我們只要得到第K個全排列,而不是所有全排列,我們不一定要將所有可能都搜索一遍。根據全排列順序的性質,我們可以總結出一個規律:假設全排列有n個數組成,則第k個全排列的第一位是k/(n-1)!。為了更形象一點,舉例如下:
123 132 213 231 312 321
在這種情況下,第一個數字每2!=2個情況就改變一次,假設求第6個排列,我們先將其減1,方便整除運算,然后5/2=2。對于第一位,我們有三種可選數字1、2、3,所以5/2=2意味著我們選擇第3個數字,也就是3(如果商是s,則選第s+1個數字)。然后將5%2得到1,這個1就是下一輪的k。
注意這里有一個技巧,就是用一個列表將1到n存起來,每選用一個數就是移出那個數,就能保證不選重復數字的同時,其順序也是一樣的。
代碼public class Solution { public String getPermutation(int n, int k) { int mod = 1; Listcandidates = new ArrayList (); // 先得到n!和候選數字列表 for(int i = 1; i <= n; i++){ mod = mod * i; candidates.add(i); } // 將k先減1方便整除 k--; StringBuilder sb = new StringBuilder(); for(int i = 0; i < n ; i++){ mod = mod / (n - i); // 得到當前應選數字的序數 int first = k / mod; // 得到用于計算下一位的k k = k % mod; sb.append(candidates.get(first)); // 在列表中移出該數字 candidates.remove(first); } return sb.toString(); } }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/64559.html
摘要:題目要求假設按照題中給的排列組合的順序,假設有個數字,返回第個排列組合的結果。最后在個位上,選擇中的第一個。這時知道以第位為開頭的結果值有此時第個結果集在該位上的選擇為。依次往后類推,直至到最后一位。 題目要求 The set [1,2,3,…,n] contains a total of n! unique permutations. By listing and labeling...
摘要:我們所找到的這個元素就是排序需要改變的第一個元素。然后我們選取一個剛好大于此元素的數,與當前元素進行替換。并對后面的所有元素重新按照升序排列就可以得到最終的答案。 題目詳情 Implement next permutation, which rearranges numbers into the lexicographically next greater permutation of...
摘要:因為增加高位會帶來更大的增益。所以對于一個長為的序列,我們增加第位的前提是,前位已經達到了最大排列方法。因為是找下一個數,所以我們要找一個比小卻盡可能大的數,所以找到。把換到的位置后,后三位仍然是個降序的排列。 Next Permutation Implement next permutation, which rearranges numbers into the lexicogr...
摘要:題目要求也就是得出所有可能的排列組合結果解題思路和代碼這題顯然采用遞歸的思路。在這里,我采用實現隊列,從隊列頭獲得上一組的結果,和當前元素結合之后,將結果插入到隊尾。 題目要求 Given a collection of distinct numbers, return all possible permutations. For example, [1,2,3] have the ...
閱讀 2293·2021-11-15 11:37
閱讀 2962·2021-09-01 10:41
閱讀 797·2019-12-27 11:58
閱讀 753·2019-08-30 15:54
閱讀 719·2019-08-30 13:52
閱讀 2936·2019-08-29 12:22
閱讀 1080·2019-08-28 18:27
閱讀 1458·2019-08-26 18:42