代碼隨想錄算法訓練營第二十九天|491.遞增子序列业踏、46.全排列、47.全排列 II

491.遞增子序列

回溯三部曲

遞歸函數(shù)參數(shù)

本題求子序列涧卵,很明顯一個元素不能重復使用勤家,所以需要startIndex,調(diào)整下一層遞歸的起始位置

遞增子序列大小至少為2

單層搜索邏輯

使用set來對本層元素進行去重

unordered_set<int>uset;// 使用set來對本層元素進行去重for(inti=startIndex;i<nums.size();i++){if((!path.empty()&&nums[i]<path.back())||uset.find(nums[i])!=uset.end()){continue;}uset.insert(nums[i]);// 記錄這個元素在本層用過了柳恐,本層后面不能再用了path.push_back(nums[i]);backtracking(nums,i+1);path.pop_back();}


巧妙的是可以用數(shù)組標記是否使用過伐脖。




46.全排列

排列問題和組合有區(qū)別

回溯三部曲

遞歸函數(shù)參數(shù)

需要一個used數(shù)組,標記已經(jīng)選擇的元素

遞歸終止條件

當收集元素的數(shù)組path的大小達到和nums數(shù)組一樣大的時候乐设,說明找到了一個全排列讼庇,也表示到達了葉子節(jié)點

單層搜索的邏輯

排列問題,每次都要從頭開始搜索?一個排列里一個元素只能使用一次

for(inti=0;i<nums.size();i++){if(used[i]==true)continue;// path里已經(jīng)收錄的元素近尚,直接跳過used[i]=true;path.push_back(nums[i]);backtracking(nums,used);path.pop_back();used[i]=false;}



47.全排列?II

同一樹層蠕啄,前一位(也就是nums[i-1])如果使用過,那么就進行去重

voidbacktracking(vector<int>&nums,vector<bool>&used){// 此時說明找到了一組if(path.size()==nums.size()){result.push_back(path);return;}for(inti=0;i<nums.size();i++){// used[i - 1] == true戈锻,說明同一樹枝nums[i - 1]使用過// used[i - 1] == false歼跟,說明同一樹層nums[i - 1]使用過// 如果同一樹層nums[i - 1]使用過則直接跳過if(i>0&&nums[i]==nums[i-1]&&used[i-1]==false){continue;}if(used[i]==false){used[i]=true;path.push_back(nums[i]);backtracking(nums,used);path.pop_back();used[i]=false;}}}?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市格遭,隨后出現(xiàn)的幾起案子哈街,更是在濱河造成了極大的恐慌,老刑警劉巖拒迅,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件骚秦,死亡現(xiàn)場離奇詭異,居然都是意外死亡坪它,警方通過查閱死者的電腦和手機骤竹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來往毡,“玉大人,你說我怎么就攤上這事靶溜】t!?“怎么了懒震?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長嗤详。 經(jīng)常有香客問我个扰,道長,這世上最難降的妖魔是什么葱色? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任递宅,我火速辦了婚禮,結(jié)果婚禮上苍狰,老公的妹妹穿的比我還像新娘办龄。我一直安慰自己,他們只是感情好淋昭,可當我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布俐填。 她就那樣靜靜地躺著,像睡著了一般翔忽。 火紅的嫁衣襯著肌膚如雪英融。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天歇式,我揣著相機與錄音驶悟,去河邊找鬼。 笑死材失,一個胖子當著我的面吹牛痕鳍,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播豺憔,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼艺沼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了嗽元?” 一聲冷哼從身側(cè)響起阴孟,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎昼榛,沒想到半個月后境肾,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡胆屿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年奥喻,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片非迹。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡环鲤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出憎兽,到底是詐尸還是另有隱情冷离,我是刑警寧澤吵冒,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布,位于F島的核電站西剥,受9級特大地震影響痹栖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜瞭空,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一揪阿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧咆畏,春花似錦南捂、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至钦讳,卻和暖如春矿瘦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背愿卒。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工缚去, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人琼开。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓易结,卻偏偏與公主長得像,于是被迫代替她去往敵國和親柜候。 傳聞我的和親對象是個殘疾皇子搞动,可洞房花燭夜當晚...
    茶點故事閱讀 43,724評論 2 351

推薦閱讀更多精彩內(nèi)容