国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

香港云服务器
服務器之家 - 編程語言 - C/C++ - C++實現LeetCode(60.序列排序)

C++實現LeetCode(60.序列排序)

2021-11-29 15:00Grandyang C/C++

這篇文章主要介紹了C++實現LeetCode(60.序列排序),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下

[LeetCode] 60. 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個數字的第k個排列組合,由于其特殊性,我們不用將所有的排列組合的情況都求出來,然后返回其第k個,這里可以只求出第k個排列組合即可,那么難點就在于如何知道數字的排列順序,首先要知道當 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

可以發現,每一位上 1,2,3,4 分別都出現了6次,當最高位上的數字確定了,第二高位每個數字都出現了2次,當第二高位也確定了,第三高位上的數字都只出現了1次,當第三高位確定了,那么第四高位上的數字也只能出現一次,下面來看 k = 17 這種情況的每位數字如何確定,由于 k = 17 是轉化為數組下標為 16:

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

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

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

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

3412 <--- k'' = 0
3421

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

3412 <--- k''' = 0

那么就可以找出規律了
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!

代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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++實現LeetCode(60.序列排序)的文章就介紹到這了,更多相關C++實現序列排序內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/grandyang/p/4358678.html

延伸 · 閱讀

精彩推薦
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
588
主站蜘蛛池模板: 在线视频一区二区 | 日韩视频一区 | 午夜在线视频 | 国产精品一区二区三区在线 | 国产成人精品久久二区二区91 | 视频一区二区三区在线观看 | 黄色一级片黄色一级片 | 成人毛片久久 | 午夜三区 | 久久国产精品久久 | 91精品啪啪 | 寡妇高潮一级片 | 久久中文字幕一区 | 成年人免费看片 | 转生成为史莱姆这档事第四季在线观看 | 高清中文字幕 | 日本中文字幕在线播放 | 色综合av | av不卡在线播放 | 成人在线小视频 | 免费成人在线视频网站 | 一特黄a大片免费视频 视频 | 日韩和的一区二在线 | 日韩福利一区二区 | 91羞羞网站 | 久久久一二三 | 一区二区三区四区在线视频 | 国产精品欧美久久久久久 | 欧美日韩亚洲成人 | 久久免费99精品久久久久久 | 欧美日韩中文字幕在线 | 一区二区视频 | 国产精品综合一区二区 | 高清av在线| 成人欧美一区二区三区视频xxx | 国产一区二区三区久久 | 国产精品高潮呻吟久久 | 亚洲日本电影 | 久久中文字幕视频 | 国产精品一二三区视频 | 一区二区三区四区在线 |