您的位置:首页 > 其它

经典算法——字符串的全部组合

2017-06-29 19:40 197 查看


#include<iostream>
#include<vector>
#include<string.h>
using namespace std;

//从头扫描字符串得到第一个字符,针对第一个字符,有两种选择
//把这个字符放到组合中去,接下来我们须要在剩下的n-1个字符中选取m-1个字符;
//假设不把这个字符放到组合中去。则须要在剩下的n-1个字符中选取m个字符
void Combination(char* string, int number, vector<char>& result)
{
if (number == 0)
{
vector<char>::iterator iter = result.begin();
for (; iter < result.end(); ++iter)
cout << (*iter);
cout << endl;
return;
}
if (*string == '\0')
return;
result.push_back(*string);
Combination(string + 1, number - 1, result);//把这个字符放到组合中去。接下来我们须要在剩下的n-1个字符中选取m-1个字符
result.pop_back();
Combination(string + 1, number, result);//不把这个字符放到组合中去,则须要在剩下的n-1个字符中选取m个字符
}

void Combination(char* string)
{
if (string == NULL)
return;
int length = strlen(string);
vector<char> result;
for (int i = 1; i <= length; i++)
{
Combination(string, i, result);
}
}

int main()
{
char s[] = "abc";
Combination(s);
system("pause");
return 0;
}


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: