中文亚洲精品无码_熟女乱子伦免费_人人超碰人人爱国产_亚洲熟妇女综合网

當(dāng)前位置: 首頁(yè) > news >正文

做網(wǎng)站需要api嗎附近電腦培訓(xùn)班位置

做網(wǎng)站需要api嗎,附近電腦培訓(xùn)班位置,百度做網(wǎng)站搜索靠前,醫(yī)療產(chǎn)品網(wǎng)站建設(shè)給出集合 [1,2,3,...,n],其所有元素共有 n! 種排列。 按大小順序列出所有排列情況,并一一標(biāo)記,當(dāng) n 3 時(shí), 所有排列如下: "123""132""213""231""312""321" 給定…

給出集合?[1,2,3,...,n],其所有元素共有?n!?種排列。

按大小順序列出所有排列情況,并一一標(biāo)記,當(dāng)?n = 3?時(shí), 所有排列如下:

  1. "123"
  2. "132"
  3. "213"
  4. "231"
  5. "312"
  6. "321"

給定?n?和?k,返回第?k?個(gè)排列。

示例 1:

輸入:n = 3, k = 3
輸出:"213"

示例 2:

輸入:n = 4, k = 9
輸出:"2314"

示例 3:

輸入:n = 3, k = 1
輸出:"123"

提示:

  • 1 <= n <= 9
  • 1 <= k <= n!

解題思路:

例如: n = 4, k = 9

????????可以知道全排列有:4*3*2*1 = 24種,如下:紅色框住的為第9個(gè)

? ? ? ? ? ? ? ??

????????從上圖可知,以1開(kāi)頭的全排列 (4-1)! = 6 共6種

? ? ? ? 9 /?6 = 1······3,也就是該數(shù)位于2開(kāi)頭的第三個(gè)。

? ? ? ? 同理,第一位2確定后,剩下三位 1 3 4,接下來(lái)需要確定第二位;

? ? ? ?

? ? ? ? ? ? ??

? ? ? ? 由上面的圖片可知, 1 3 4全排列每一列分別有兩個(gè)數(shù)3-1)!,3 / 2 = 1······1,可知位于第二列開(kāi)頭的第一個(gè)

然后確定第三位 ,第三位則還剩下2個(gè)數(shù):1和4;

? ? ? ? 1和4的全排列:

? ? ? ?

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?

? ? ? ? 1 4排列,每類(lèi)(2-1)! = 1,1 / 1 = 1·····0,可知位于1開(kāi)頭的第一個(gè)

? ? ? ? 最后一位數(shù),只有一種情況:? (1-1)! = 1

具體算法如下:

1、定義一個(gè)逆康托數(shù)組,記錄n位數(shù)字對(duì)應(yīng)每個(gè)數(shù)字開(kāi)頭序列的個(gè)數(shù),例如4位數(shù)prenum[1, 1, 2, 6]

將k值-1,再進(jìn)行計(jì)算,這里-1是為了? 9 % 6 = 3,而數(shù)組下標(biāo)從0開(kāi)始,-1后方便計(jì)算。

2、定義一個(gè)valid數(shù)組[0.....n];記錄還沒(méi)有被使用的數(shù)字, 已經(jīng)使用的需要移除

3、(k -1 ) / prenum[n - i - 1]? ?+ 1就是分別計(jì)算每一位數(shù)字位于那一列;例如 (9 -1)/ 6? + 1= 2,說(shuō)明第一個(gè)數(shù)字為2,ans累加vali[2] ,2被使用后erase掉,valid中剩余[0,1,3,4]

? ? ? ? 然后k記錄剩余未計(jì)算的數(shù) 8 % 6 = 2

? ? ? ? k = 2再重復(fù)計(jì)算,可得到 2/2 + 1 = 2;? 再取走valid中的第2個(gè)

? ? ? ? 同理依次取完。

完整代碼如下:

class Solution {
public:string getPermutation(int n, int k) {//prenum = {0!, 1!, 2!, 3!, .....(n-1)!}vector<int> pernum(n);pernum[0] = 1;for(int i= 1; i < n; i++) {pernum[i] = pernum[i-1] * i;}//k-- 方便取余后計(jì)算k--;string ans;vector<int> valid(n+1);//生成[0,1,2....n]的數(shù)組iota(valid.begin(), valid.end(), 0);for(int i = 0; i < n; i++) {int order = k / pernum[n-i-1] + 1;ans += (valid[order] + '0');//用了就從數(shù)組中刪除valid.erase(valid.begin() + order);k %= pernum[n-i-1];}return ans;}
};

拓展:康托展開(kāi),也就是在全排列中,給定一個(gè)序列,求該序列位于第幾個(gè)。

#include <iostream>
#include <string>
using namespace std;class Solution {public://求階乘int fact(int x) {int ret = 1;for(int i = 2; i <= x; i++) {ret *= i;}return ret;}int getStringId(string str) {int len = str.size();int ans = 0;for(int i = 0; i < len; i++) {int cnt = 0;//記錄后面的數(shù)有幾個(gè)比當(dāng)前的數(shù)小;//例如2314  314中只有1個(gè)數(shù)比第一位小,說(shuō)明該數(shù)位于第二列。for(int j = i + 1 ; j < len; j++) {if(str[j] < str[i]) {cnt ++;}}ans += cnt*fact(len- i -1);}return ans+1;}
};
int main()
{string s;cin >> s;Solution sol;cout << "位于序列第:" << sol.getStringId(s) << " 位" << endl;return 0;
}

http://www.risenshineclean.com/news/48111.html

相關(guān)文章:

  • 網(wǎng)站建設(shè)與維護(hù)的題目seo公司怎樣找客戶(hù)
  • 南沙網(wǎng)站建設(shè)wwiw搜索引擎外部鏈接優(yōu)化
  • 營(yíng)銷(xiāo)型網(wǎng)站建設(shè)的優(yōu)缺點(diǎn)seo免費(fèi)診斷
  • 做游戲評(píng)論注冊(cè)國(guó)外網(wǎng)站一份完整的品牌策劃方案
  • 二級(jí)網(wǎng)站建設(shè)費(fèi)用南寧網(wǎng)站推廣公司
  • 云南網(wǎng)站設(shè)計(jì)公司淘寶關(guān)鍵詞搜索工具
  • 鄭州制作網(wǎng)站軟件杭州seo關(guān)鍵詞優(yōu)化公司
  • 北京企業(yè)建站服務(wù)中企關(guān)鍵詞首頁(yè)排名代發(fā)
  • 北京住房城鄉(xiāng)建設(shè)網(wǎng)站全網(wǎng)推廣的方式
  • 做外貿(mào)網(wǎng)站公司哪家關(guān)鍵詞搜索引擎工具
  • 在東營(yíng)怎么建網(wǎng)站百度seo公司報(bào)價(jià)
  • 電腦版瀏覽器在線使用seo網(wǎng)絡(luò)推廣公司報(bào)價(jià)
  • 免費(fèi)做章子的網(wǎng)站手機(jī)優(yōu)化器
  • wordpress xmlrpc api廣州seo好找工作嗎
  • 安徽炒股配資網(wǎng)站開(kāi)發(fā)淘寶關(guān)鍵詞怎么做排名靠前
  • 果麥傳媒的網(wǎng)站怎么做的nba排名最新賽程
  • 新農(nóng)村基礎(chǔ)設(shè)施建設(shè)網(wǎng)站國(guó)外十大免費(fèi)服務(wù)器和域名
  • 網(wǎng)頁(yè)設(shè)計(jì)企業(yè)網(wǎng)站設(shè)計(jì)的功能項(xiàng)目推廣方式有哪些
  • 傳誠(chéng)信網(wǎng)站建設(shè)營(yíng)銷(xiāo)失敗案例分析
  • 建個(gè)企業(yè)網(wǎng)站有什么用哪里注冊(cè)域名最便宜
  • 網(wǎng)站開(kāi)發(fā)軟件福州網(wǎng)站優(yōu)化
  • 網(wǎng)站程序結(jié)構(gòu)九江seo
  • wordpress發(fā)布圖片插件網(wǎng)站標(biāo)題seo外包優(yōu)化
  • 在國(guó)外做h網(wǎng)站怎么樣百度關(guān)鍵字優(yōu)化精靈
  • 做擦邊網(wǎng)站 服務(wù)器放在狗爹昆明seo優(yōu)化
  • 珠海網(wǎng)站建設(shè)聯(lián)系方式上海關(guān)鍵詞優(yōu)化按天計(jì)費(fèi)
  • 深圳考試培訓(xùn)網(wǎng)站建設(shè)域名解析查詢(xún)工具
  • 濱海住房和城鄉(xiāng)建設(shè)局網(wǎng)站網(wǎng)絡(luò)營(yíng)銷(xiāo)的核心是
  • 中國(guó)建設(shè)銀行招聘信息網(wǎng)站6一個(gè)新手怎么做電商
  • 小公司如何做網(wǎng)站隔離直通車(chē)推廣計(jì)劃方案