全排列 【dfs回溯】+【set去重】
来源:互联网 发布:网络销售是正规工作么 编辑:程序博客网 时间:2024/06/07 23:34
给出一个字符串S(可能有重复的字符),按照字典序从小到大,输出S包括的字符组成的所有排列。例如:S = “1312”,
输出为:
1123
1132
1213
1231
1312
1321
2113
2131
2311
3112
3121
3211
Input
输入一个字符串S(S的长度 <= 9,且只包括0 - 9的阿拉伯数字)
Output
输出S所包含的字符组成的所有排列
Input示例
1312
Output示例
1123
1132
1213
1231
1312
1321
2113
2131
2311
3112
3121
3211
解析 : 首先肯定用dfs没问题,先用了dfs就会发现会有重复元素,所以要 去重,所以就想到了可以用set来维护。。
代码
#include<cstdio>#include<cstring>#include<algorithm>#include<iostream>#include<cmath>#include<queue>#include<stack>#include<map>#include<vector>#include<set>#define CLR(a,b) memset((a),(b),sizeof(a))#define inf 0x3f3f3f3f#define mod 100009#define LL long long#define M 10000#define ll o<<1#define rr o<<1|1#define lson o<<1,l,mid#define rson o<<1|1,mid+1,rusing namespace std;char s[12];char ss[12];int len;int vis[12]; set<string>S;void dfs(int step) //得到全排列{ if(step==len) S.insert(ss); // 去重 for(int i=0;i<len;i++) { if(!vis[i]) { vis[i]=1; ss[step]=s[i]; dfs(step+1); vis[i]=0; } }}int main(){ gets(s); len=strlen(s); sort(s,s+len); memset(vis,0,sizeof(vis)); dfs(0); set<string>::iterator it; for(it=S.begin();it!=S.end();it++) cout<<*it<<endl; return 0;}
0 0
- 全排列 【dfs回溯】+【set去重】
- 全排列 DFS 回溯
- 全排列去重
- ZOJ-2734-Exchange Cards(DFS全排列+去重)
- 去重的全排列
- 全排列(DFS递归+STL set)
- 递归的全排列去重算法
- 全排列 去重 非字典序
- JavaScript趣题:全排列去重
- USACO ORZ(DFS+set去重)
- HDU 4277 dfs+set去重
- 回溯全排列
- 【回溯】全排列
- 回溯法 全排列
- 全排列,回溯
- 全排列 递归+回溯
- 全排列 回溯
- 全排列回溯算法
- Oracle 安装
- LeetCode部分题解
- Fedora25安装fiddler
- 51 nod 1241 特殊的排序(思维)@
- 【面向对象】三大特性——封装、继承、多态
- 全排列 【dfs回溯】+【set去重】
- 企业QQ空间xss随意得客户端QQ号码 附(爆破盗号者后台)
- 【提高篇】经典算法——有序表的二分查找
- Java 初始化与清理
- Java反射三 构造方法
- Windows下编译qt-material
- Leetcode-标签为Tree 110. Balanced Binary Tree
- spring mvc 标签,@PathVariable,@cookieValue ,@RequestHeader等
- 面试13之检查链表是否为回文