程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> 經典算法——字符串的所有組合

經典算法——字符串的所有組合

編輯:關於C++

\

#include
#include
#include
using namespace std;

//從頭掃描字符串得到第一個字符,針對第一個字符,有兩種選擇
//把這個字符放到組合中去,接下來我們需要在剩下的n-1個字符中選取m-1個字符;
//如果不把這個字符放到組合中去,則需要在剩下的n-1個字符中選取m個字符 
void Combination(char* string, int number, vector& result)
{
	if (number == 0)
	{
		vector::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 result;
	for (int i = 1; i <= length; i++)
	{
		Combination(string, i, result);
	}
}

int main()
{
	char s[] = "abc";
	Combination(s);
	system("pause");
	return 0;
}
\
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved