字串的組合

2021-08-31 16:59:56 字數 913 閱讀 6442

***

題目:輸入乙個字串,輸出該字串中字元的所有組合。舉個例子,如果輸入

abc,它的組合有a、

b、c、

ab、ac、

bc、abc。

分析:在本系列部落格的第

28題《

字串的排列

》中,我們詳細討論了如何用遞迴的思路求字串的排列。同樣,本題也可以用遞迴的思路來求字串的組合。

假設我們想在長度為

n的字串中求

m個字元的組合。我們先從頭掃瞄字串的第乙個字元。針對第乙個字元,我們有兩種選擇:一是把這個字元放到組合中去,接下來我們需要在剩下的

n-1個字元中選取

m-1個字元;而是不把這個字元放到組合中去,接下來我們需要在剩下的

n-1個字元中選擇

mvoid

combination(char* string)

} void

combination(char* string, int number, vector& result)

if(*string == '\0')

return;

result.push_back(*string);

combination(string + 1, number - 1, result);

result.pop_back();

combination(string + 1, number, result); }

由於組合可以是

1個字元的組合,

2個字元的字元……一直到

n個字元的組合,因此在函式

void combination(char* string)

,我們需要乙個

for迴圈。另外,我們乙個

vector

來存放選擇放進組合裡的字元。

字串組合

題目 輸入乙個字串,輸出該字串中字元的所有組合。舉個例子,如果輸入 abc,它的組合有a b c ab ac bc abc。假設我們想在長度為 n的字串中求 m個字元的組合。我們先從頭掃瞄字串的第乙個字元。針對第乙個字元,我們有兩種選擇 一是把這個字元放到組合中去,接下來我們需要在剩下的 n 1個字...

字串的組合

問題描述 輸入乙個字串,輸出它的所有組合。例如,輸入abc,則輸出 a b c ab ac bc abc。分析 如果輸入的字串的長度為n,則這個字串能構成長度為1的組合 長度為2的組合 長度為n的組合。在求n個字元的長度為m 1 m n 的組合的時候,我們可以把這n個字元分成兩部分 第乙個字元和其餘...

字串的組合

題意 對乙個字串str,求其字元的所有組合。例如字串abc,其組合就有a b c ab ac bc abc 解題思路 上述問題等價於在字串str中,求長度為1,2,3,n的子串的集合。現在要解決的問題就是在長度為n的字串中求長度為m的子串有哪些。將待處理的字串分為兩部分,第乙個字元為第一部分,剩餘的...