亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

【Python】遞歸實現(xiàn)n的全排列

系統(tǒng) 1914 0

這是面試字節(jié)跳動的大數(shù)據(jù)崗位時候面試官給的一個題目,就是輸出n個數(shù)的全排列。

當n=1是,perm(1)= [[1]]

當n=2是,對于perm(1)里面的每個子list,n可以在list的第0個位置到最后一個位置,這里perm(1)里只有一個子list [1],所以perm(2)= [[2,1],[1,2]]

當n=3時,perm(2)的子list有[2,1]和[1,2],
對于子list為[2,1],3可以插入到[2,1]的第0個位置,到第二個位置,分別為[3,2,1],[2,3,1],[2,1,3],同樣對于子list為[1,2]時,可以得到[3,1,2],[1,3,2],[1,2,3]
得到perm(3)=[[3,2,1],[2,3,1],[2,1,3],[3,1,2],[1,3,2],[1,2,3]]

因此對于perm(n)來說,先取perm(n-1)的每個子列表,然后依次在每個子列表中的每個位置插入n,即可得到perm(n)。

代碼示例:

            
              
                import
              
               copy

def 
              
                perm
              
              
                (
              
              n
              
                )
              
              
                :
              
              
    data 
              
                =
              
              
                [
              
              
                ]
              
              
                if
              
              
                (
              
              n 
              
                ==
              
              
                1
              
              
                )
              
              
                :
              
              
        data
              
                .
              
              
                append
              
              
                (
              
              
                [
              
              
                1
              
              
                ]
              
              
                )
              
              
                else
              
              
                :
              
              
                for
              
               m 
              
                in
              
              
                pai
              
              
                (
              
              n
              
                -
              
              
                1
              
              
                )
              
              
                :
              
              
                for
              
               j 
              
                in
              
              
                range
              
              
                (
              
              
                len
              
              
                (
              
              m
              
                )
              
              
                +
              
              
                1
              
              
                )
              
              
                :
              
              
                k 
              
                =
              
               copy
              
                .
              
              
                copy
              
              
                (
              
              m
              
                )
              
              #淺拷貝
                k
              
                .
              
              
                insert
              
              
                (
              
              j
              
                ,
              
              n
              
                )
              
              
                data
              
                .
              
              
                append
              
              
                (
              
              k
              
                )
              
              
                return
              
               data

              
                perm
              
              
                (
              
              
                4
              
              
                )
              
            
          

結(jié)果:
[[4, 3, 2, 1],
[3, 4, 2, 1],
[3, 2, 4, 1],
[3, 2, 1, 4],
[4, 2, 3, 1],
[2, 4, 3, 1],
[2, 3, 4, 1],
[2, 3, 1, 4],
[4, 2, 1, 3],
[2, 4, 1, 3],
[2, 1, 4, 3],
[2, 1, 3, 4],
[4, 3, 1, 2],
[3, 4, 1, 2],
[3, 1, 4, 2],
[3, 1, 2, 4],
[4, 1, 3, 2],
[1, 4, 3, 2],
[1, 3, 4, 2],
[1, 3, 2, 4],
[4, 1, 2, 3],
[1, 4, 2, 3],
[1, 2, 4, 3],
[1, 2, 3, 4]]


更多文章、技術(shù)交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久剧场 | 伊在人亚洲香蕉精品播放 | 伊人网在线播放 | 国产精品久久久久久久久岛 | 亚洲国产最新 | 久久久国产成人精品 | 天堂网一区二区 | 九九热国产精品视频 | 日本3p视频在线看高清 | 亚洲一区免费在线观看 | 可以免费观看一级毛片黄a 可以直接看的毛片 | 国产福利一区二区在线观看 | 国产97在线视频观看 | 国产v片成人影院在线观看 国产v视频 | 日韩一区二区三区四区 | 日日夜夜综合 | 国产成人精品一区二区不卡 | 国产99久久久久久免费看 | 爱爱99 | 国产精品亚洲欧美日韩一区在线 | 九九精品国产兔费观看久久 | 在线日产一区二区 | 日日爽夜夜操 | 久久久久久久综合色一本 | ijzzijzz精的女人美女 | 四虎日韩 | 99九九精品免费视频观看 | 4hu四虎免费影院www | 久久视屏这里只有精品6国产 | 久久这里只有精品99 | 在线不卡福利 | 性视频一区二区三区免费 | 欧美日韩视频精品一区二区 | 久久久99精品 | 精品免费福利视频 | 国产成人综合亚洲一区 | 国产成人精品日本亚洲专一区 | 亚洲精品一区二区三区四区 | 手机看片国产免费久久网 | 91精品啪国产在线观看免费牛牛 | 久久精品视频1 |