LeetCode算法題-31. 下一個(gè)排列(Swift)

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/next-permutation
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請聯(lián)系官方授權(quán)粘衬,非商業(yè)轉(zhuǎn)載請注明出處摧玫。

題目

實(shí)現(xiàn)獲取下一個(gè)排列的函數(shù),算法需要將給定數(shù)字序列重新排列成字典序中下一個(gè)更大的排列衅斩。

如果不存在下一個(gè)更大的排列盆顾,則將數(shù)字重新排列成最小的排列(即升序排列)。

必須原地修改畏梆,只允許使用額外常數(shù)空間您宪。

以下是一些例子奈懒,輸入位于左側(cè)列,其相應(yīng)輸出位于右側(cè)列宪巨。

1,2,3 → 1,3,2
3,2,1 → 1,2,3
1,1,5 → 1,5,1

不明白題意磷杏,但是看解析是說。是這樣
1捏卓、先找出最大的索引 k 滿足 nums[k] < nums[k+1]极祸,如果不存在,就翻轉(zhuǎn)整個(gè)數(shù)組怠晴;
2遥金、再找出另一個(gè)最大索引 l 滿足 nums[l] > nums[k];
3龄寞、交換 nums[l] 和 nums[k]汰规;
4、最后翻轉(zhuǎn) nums[k+1:]物邑。

方法

 func nextPermutation(_ nums: inout [Int]) {
        
        if nums.count == 0 {
            return
        }
        var firstIndex = -1
        for i in stride(from: nums.count - 2, through: 0, by: -1) {
            if nums[i] < nums[i+1] {
                firstIndex = i
                break
            }
        }
        
        if firstIndex == -1 {
            reverseNums(&nums, 0, nums.count - 1)
            return
        }
        
        var secondIndex = -1
        for i in stride(from: nums.count - 1, through: 0, by: -1) {
            if nums[i] > nums[firstIndex] {
                secondIndex = i
                break
            }
        }

        swapNums(&nums, firstIndex, secondIndex)
        reverseNums(&nums, firstIndex + 1, nums.count - 1)
        return;

    }
    
    func reverseNums(_ nums: inout [Int], _ fromIndex: Int, _ toIndex: Int) {
        
        var fromIndex = fromIndex
        var toIndex = toIndex
        
        while fromIndex < toIndex {
            swapNums(&nums, fromIndex , toIndex)
            fromIndex += 1
            toIndex -= 1
        }
    }
    func swapNums(_ nums: inout [Int], _ fromIndex: Int, _ toIndex: Int) {
        let tmp = nums[fromIndex];
        nums[fromIndex] = nums[toIndex];
        nums[toIndex] = tmp;
    }
image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末溜哮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子色解,更是在濱河造成了極大的恐慌茂嗓,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件科阎,死亡現(xiàn)場離奇詭異述吸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)锣笨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進(jìn)店門蝌矛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人错英,你說我怎么就攤上這事入撒。” “怎么了椭岩?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵茅逮,是天一觀的道長。 經(jīng)常有香客問我判哥,道長献雅,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任塌计,我火速辦了婚禮挺身,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘夺荒。我一直安慰自己瞒渠,他們只是感情好良蒸,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布技扼。 她就那樣靜靜地躺著伍玖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪剿吻。 梳的紋絲不亂的頭發(fā)上窍箍,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天,我揣著相機(jī)與錄音丽旅,去河邊找鬼椰棘。 笑死,一個(gè)胖子當(dāng)著我的面吹牛榄笙,可吹牛的內(nèi)容都是我干的邪狞。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼茅撞,長吁一口氣:“原來是場噩夢啊……” “哼帆卓!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起米丘,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤剑令,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后拄查,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吁津,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年堕扶,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了碍脏。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,785評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡稍算,死狀恐怖典尾,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情邪蛔,我是刑警寧澤急黎,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站侧到,受9級特大地震影響勃教,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜匠抗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一故源、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧汞贸,春花似錦绳军、人聲如沸印机。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽射赛。三九已至,卻和暖如春奶是,著一層夾襖步出監(jiān)牢的瞬間楣责,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工聂沙, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留秆麸,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓及汉,卻偏偏與公主長得像沮趣,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子坷随,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評論 2 354

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