生成全排列

#include<assert.h>

#include<iostream>

#include<fstream>

#include<time.h>

#include<stack>

using namespace std;







struct Node

{

	int i;

	int dept;

	Node(int id,int depth)

	{

		i=id;

		dept=depth;

	}

};



template<class E>

void permutation(E  *arr,int n,ofstream &cout)

{

	assert(n>0);

	int * count=new int [n];



	stack<Node *> myStack;

	for(int i=0;i<n;i++)

	{

		myStack.push(new Node(i,0));

	}

	int index=0;

	int num=0;

	while(myStack.empty()==false)

	{

		Node *now=myStack.top();

		myStack.pop();

		index=now->dept;

		count[index]=now->i;

		if(index==n-1)

		{

			num++;

			cout<<"µÚ"<<num<<"ÖÖÅÅÁÐ:"<<endl;

			for(int i=0;i<n;i++)

			{

				cout<<arr[count[i]]<<"  ";

			}

			cout<<endl;

		}

		for(int i=0;i<n;i++)

		{

			int j;

			for(j=0;j<=index;j++)

			{

				if(count[j]==i)

					break;

			}

			if(j<=index)

			{

			}

			else

			{

				myStack.push(new Node(i,index+1));

			}

		}

	}

}

int main()

{

	ofstream cout("output.txt");

	int n=4;

	char *arr=new char[n+1];

	for(int i=0;i<=n;i++)

	{

		arr[i]='a'+i;

	}

	arr[n]='\0';

	permutation<char>(arr,n,cout);

	return 0;

}
虽然此程序 ,不可能在可接受的时间内输出全排列,但是却可以在一定的内存条件,无限的时间下得到全排列。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值