基于深度优先的全排序算法(递归)

对于全排序的每一个位置,都可以放任一允许放置的元素(未被使用过)

#include<iostream>
#include<cmath>
#include<vector>
#include<queue>
#include<map>
#include<stack>
#include<fstream>
#include<algorithm>
using namespace std;
void full(map<int,bool>ma,queue<int>out,int cur){//采用map主要是将要排列的元素附加一个标记位,out为输出队列,cur为当前标记位或者说是已经选择的数目 
	if(cur==ma.size()){//元素全部选完,即已经生成一种全排序 
		while(!out.empty()){
			cout<<out.front();
			out.pop();
		}
		cout<<endl;
		return;
	}
	
	for(map<int,bool>::iterator iter = ma.begin();iter!=ma.end();iter++){
		
		if(iter->second==true){//此元素未被使用过 
			queue<int>out1 = out;//保留一个副本作为还原现场用 
			out.push(iter->first);
			iter->second = false;
			full(ma,out,cur+1);
			//还原现场 
			iter->second = true;
			out = out1;
		}
	}
} 
int main(){
	map<int,bool>ma;
	for(int i=1;i<=4;i++)ma[i]=true;
	queue<int>s2;
	full(ma,s2,0);

return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值