# -*- coding: utf-8 -*-
# @Time : 2019-07-08 9:52
# @Author : Jayce Wong
# @ProjectName : job
# @FileName : stringCombination.py
# @Blog : https://blog.51cto.com/jayce1111
# @Github : https://github.com/SysuJayce
class Solution:
"""
排列組合一般都可通過(guò)遞歸來(lái)解決。
先確定遞歸出口:當(dāng)找到了一個(gè)既定長(zhǎng)度的組合或者剩余的字符不足以湊成既定長(zhǎng)度的組合就該結(jié)束該層遞歸
然后確定如何遞歸:長(zhǎng)度為n的字符串的組合的長(zhǎng)度在1到n之間,而對(duì)于長(zhǎng)度為m的其中一個(gè)組合,若在給定
字符中第一個(gè)字符不選,那么需要從剩余的n-1個(gè)字符中選擇m個(gè)字符;
若選擇第一個(gè)字符,那么需要從剩余的n-1個(gè)字符中選擇m-1個(gè)字符。
注意兩種選擇是互斥的,因此在結(jié)束一種選擇之后需要確保還原狀態(tài)
"""
def Combination(self, ss):
"""
對(duì)給定字符串進(jìn)行全排列
:param ss: 帶排列字符串
:return: 一個(gè)列表,包含所有可能的排列,其中元素順序符合字典序
"""
def helper(s, length):
# 如果剩余位數(shù)為0,那么代表既定長(zhǎng)度的字符串組合已經(jīng)找到,添加到結(jié)果中
if length == 0:
ans.add(''.join(temp))
# 如果剩余的可選字符為0,那么結(jié)束
elif not s:
return
else:
# 否則,先將第一個(gè)字符加入temp列表中,然后從剩余字符中選length-1個(gè)
temp.append(s[0])
helper(s[1:], length - 1)
# 或者,第一個(gè)字符不選,從剩余字符中選length個(gè)。那么就先要將第一個(gè)字符從temp
# 列表中剔除
temp.pop(-1)
helper(s[1:], length)
if not ss:
return []
ans = set()
temp = []
for i in range(1, len(ss) + 1):
helper(list(ss), i)
return sorted(list(ans), key=lambda x: (len(x), x))
def main():
s = "abc"
solution = Solution()
ans = solution.Combination(s)
print(ans)
if __name__ == '__main__':
main()
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
目前累計(jì)服務(wù)客戶上千余家,積累了豐富的產(chǎn)品開(kāi)發(fā)及服務(wù)經(jīng)驗(yàn)。以網(wǎng)站設(shè)計(jì)水平和技術(shù)實(shí)力,樹(shù)立企業(yè)形象,為客戶提供做網(wǎng)站、網(wǎng)站制作、網(wǎng)站策劃、網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)絡(luò)營(yíng)銷、VI設(shè)計(jì)、網(wǎng)站改版、漏洞修補(bǔ)等服務(wù)。創(chuàng)新互聯(lián)公司始終以務(wù)實(shí)、誠(chéng)信為根本,不斷創(chuàng)新和提高建站品質(zhì),通過(guò)對(duì)領(lǐng)先技術(shù)的掌握、對(duì)創(chuàng)意設(shè)計(jì)的研究、對(duì)客戶形象的視覺(jué)傳遞、對(duì)應(yīng)用系統(tǒng)的結(jié)合,為客戶提供更好的一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶,共同發(fā)展進(jìn)步。