溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C++如何實現(xiàn)序列排序

發(fā)布時間:2022-03-28 10:55:12 來源:億速云 閱讀:277 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要講解了“C++如何實現(xiàn)序列排序”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“C++如何實現(xiàn)序列排序”吧!

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 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.

  • Given k will be between 1 and n! inclusive.

Example 1:

Input: n = 3, k = 3
Output: "213"

Example 2:

Input: n = 4, k = 9
Output: "2314"

這道題是讓求出n個數(shù)字的第k個排列組合,由于其特殊性,我們不用將所有的排列組合的情況都求出來,然后返回其第k個,這里可以只求出第k個排列組合即可,那么難點就在于如何知道數(shù)字的排列順序,首先要知道當 n = 3 時,其排列組合共有 3! = 6 種,當 n = 4 時,其排列組合共有 4! = 24 種,這里就以 n = 4, k = 17 的情況來分析,所有排列組合情況如下:

1234
1243
1324
1342
1423
1432
2134
2143
2314  
2341
2413
2431
3124
3142
3214
3241
3412 <---  k = 17
3421
4123
4132
4213
4231
4312
4321

可以發(fā)現(xiàn),每一位上 1,2,3,4 分別都出現(xiàn)了6次,當最高位上的數(shù)字確定了,第二高位每個數(shù)字都出現(xiàn)了2次,當?shù)诙呶灰泊_定了,第三高位上的數(shù)字都只出現(xiàn)了1次,當?shù)谌呶淮_定了,那么第四高位上的數(shù)字也只能出現(xiàn)一次,下面來看 k = 17 這種情況的每位數(shù)字如何確定,由于 k = 17 是轉(zhuǎn)化為數(shù)組下標為 16:

最高位可取 1,2,3,4 中的一個,每個數(shù)字出現(xiàn) 3!= 6 次(因為當最高位確定了,后面三位可以任意排列,所以是 3!,那么最高位的數(shù)字就會重復(fù) 3!次),所以 k = 16 的第一位數(shù)字的下標為 16 / 6 = 2,在 "1234" 中即3被取出。這里的k是要求的坐標為k的全排列序列,定義 k" 為當最高位確定后,要求的全排序列在新范圍中的位置,同理,k"" 為當?shù)诙邽榇_定后,所要求的全排列序列在新范圍中的位置,以此類推,下面來具體看看:

第二位此時從 1,2,4 中取一個,k = 16,則此時的 k" = 16 % (3!) = 4,注意思考這里為何要取余,如果對這 24 個數(shù)以6個一組來分,那么 k=16 這個位置就是在第三組(k/6 = 2)中的第五個(k%6 = 4)數(shù)字。如下所示,而剩下的每個數(shù)字出現(xiàn) 2!= 2 次,所以第二數(shù)字的下標為 4 / 2 = 2,在 "124" 中即4被取出。

3124
3142
3214
3241
3412 <--- k" = 4
3421

第三位此時從 1,2 中去一個,k" = 4,則此時的 k"" = 4 % (2!) = 0,如下所示,而剩下的每個數(shù)字出現(xiàn) 1!= 1 次,所以第三個數(shù)字的下標為 0 / 1 = 0,在 "12" 中即1被取出。

3412 <--- k"" = 0
3421

第四位是從2中取一個,k"" = 0,則此時的 k""" = 0 % (1!) = 0,如下所示,而剩下的每個數(shù)字出現(xiàn) 0!= 1 次,所以第四個數(shù)字的下標為 0 / 1= 0,在 "2" 中即2被取出。

3412 <--- k""" = 0

那么就可以找出規(guī)律了
a1 = k / (n - 1)!
k1 = k

a2 = k1 / (n - 2)!
k2 = k1 % (n - 2)!
...

an-1 = kn-2 / 1!
kn-1 = kn-2 % 1!

an = kn-1 / 0!
kn = kn-1 % 0!

代碼如下:

class Solution {
public:
    string getPermutation(int n, int k) {
        string res;
        string num = "123456789";
        vector<int> f(n, 1);
        for (int i = 1; i < n; ++i) f[i] = f[i - 1] * i;
        --k;
        for (int i = n; i >= 1; --i) {
            int j = k / f[i - 1];
            k %= f[i - 1];
            res.push_back(num[j]);
            num.erase(j, 1);
        }
        return res;
    }
};

感謝各位的閱讀,以上就是“C++如何實現(xiàn)序列排序”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對C++如何實現(xiàn)序列排序這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

c++
AI