剑指Offer-27.字符串的排列(C++/Java)
题目:
输入描述:
输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。
分析:
可以采用递归和非递归两种方法实现。
递归方法使用交换的的思路,我们可以将字符串看成两部分,第一个字符和后面的字串,将第一个字符和后面的每一元素互换,这样就会产生新的排列,然后再递归执行后面的字串,具体流程如图:

出自:https://blog.csdn.net/zxzxzx0119/article/details/81452269
第二种方法可以先取一个元素到结果集,然后遍历字串剩余的元素将每一个元素插入到结果集中字符串的每一个位置,删掉取出的结果,再讲新结果存进结果集用{a,b,c}举例。
结果集中是{a}
取结果集字符串{a},并在结果集中删掉{a},将剩余元素b插入串{a}的每一个位置得到{b,a},{a,b}。
取{b,a},结果集还剩{a,b}
将c插入{b,a}得到{c,b,a},{b,c,a},{b,a,c},将三个结果添加进结果集,此时{a,b},{c,b,a},{b,c,a},{b,a,c}
再取出{a,b}将c插入得,{c,a,b},{a,c,b},{a,b,c},添加进结果集,此时{c,b,a},{b,c,a},{b,a,c},{c,a,b},{a,c,b},{a,b,c}
小技巧就是每次从结果集的后面取出元素,在前面插入新的结果。
不过这道题要求是有重复元素的,可以使用set来去重,不过牛客网的判题很迷,顺序不同也会判错。可以排个序再输出。

程序:
C++
class Solution {
public:
vector<string> Permutation(string str) {
if(str.size() == )
return res;
helper(str, );
for(auto i:tempRes)
res.push_back(i);
return res;
}
void helper(string str, int index){
if(index == str.size()-)
//res.push_back(str);
tempRes.insert(str);
for(int i = index; i < str.size(); ++i){
swap(str[index], str[i]);
helper(str, index+);
}
}
vector<string> res;
set<string> tempRes;
};
class Solution {
public:
vector<string> Permutation(string str) {
if(str.size() == )
return res;
res.push_back(str.substr(, ));
strSet.insert(str.substr(, ));
for(int i = ; i < str.size(); ++i){
int m = res.size();
for(int j = ; j < m; ++j){
string tempStr = res.back();
res.pop_back();
for(int k = ; k <= tempStr.size(); ++k){
string ttempStr = tempStr;
ttempStr.insert(k, str.substr(i,));
set<string>::iterator iter;
if((iter = strSet.find(ttempStr)) == strSet.end()){
res.insert(res.begin(), ttempStr);
strSet.insert(ttempStr);
}
}
}
}
sort(res.begin(), res.end());
return res;
}
private:
set<string> strSet;
vector<string> res;
};
Java
import java.util.ArrayList;
import java.util.Collections;
//import java.util.HashSet;
public class Solution {
public ArrayList<String> Permutation(String str) {
if(str.length() == 0)
return res;
StringBuilder s = new StringBuilder(str);
Helper(s, 0);
Collections.sort(res);
return res;
}
public void Helper(StringBuilder s, int index){
if(index == s.length()-1)
res.add(s.toString());
for(int i = index; i < s.length(); ++i){
if(s.charAt(index) != s.charAt(i) || index == i){
Swap(s, index, i);
Helper(s, index+1);
Swap(s, index, i);
}
}
}
public static void Swap(StringBuilder s, int i, int j) {
char temp = s.charAt(i);
s.setCharAt(i, s.charAt(j));
s.setCharAt(j, temp);
}
private ArrayList<String> res = new ArrayList<>();
//private HashSet<String> set = new HashSet<>();
}
剑指Offer-27.字符串的排列(C++/Java)的更多相关文章
- 剑指Offer 27. 字符串的排列 (字符串)
题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入描述: 输 ...
- [剑指Offer] 27.字符串的排列
[思路]从第一位开始,判断每一位字符的所有可能性,依此递归. class Solution { public: void PermutationHelp(vector<string> &a ...
- 剑指 Offer 38. 字符串的排列 + 无重复元素的全排列
剑指 Offer 38. 字符串的排列 Offer_38 题目描述 解题思路 可以使用递归实现全排列,每次都确定一个数的位置,当所有位置的数都确定后即表示一个排列. 但是考虑到本题需要排除重复的排列, ...
- 剑指 Offer 38. 字符串的排列
剑指 Offer 38. 字符串的排列 输入一个字符串,打印出该字符串中字符的所有排列. 你可以以任意顺序返回这个字符串数组,但里面不能有重复元素. 示例: 输入:s = "abc" ...
- 【剑指Offer】字符串的排列 解题报告(Python)
[剑指Offer]字符串的排列 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https://www.nowcoder.com/ta/coding-interviews 题 ...
- 【Java】 剑指offer(38) 字符串的排列
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 输入一个字符串,打印出该字符串中字符的所有排列.例如输入字符串ab ...
- Go语言实现:【剑指offer】字符串的排列
该题目来源于牛客网<剑指offer>专题. 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,b ...
- 《剑指offer》字符串的排列
本题来自<剑指offer> 反转链表 题目: 思路: C++ Code: Python Code: 总结:
- 剑指offer:字符串的排列
题目描述: 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入描述: ...
- 剑指OFFER之字符串的排列(九度OJ1369)
题目描述: 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入: 每个 ...
随机推荐
- solr学习篇(二) solr 分词器篇
关于solr7.4搭建与配置可以参考 solr7.4 安装配置篇 在这里我们探讨一下分词的配置 目录 关于分词 配置分词 验证成功 1.关于分词 1.分词是指将一个中文词语拆成若干个词,提供搜索引擎 ...
- anaconda重装jupyter notebook后启动jupyter报错的问题
问题描述: 由于jupyter出现难以解决的问题,采用重新安装来解决问题,但是重装之后启动jupyter报错ImportError: libsodium.so.23: cannot open shar ...
- python-nmap使用及案例
nmap概念及功能 概念 NMap,也就是Network Mapper,最早是Linux下的网络扫描和嗅探工具包. nmap是一个网络连接端扫描软件,用来扫描网上电脑开放的网络连接端.确定哪些服务运行 ...
- Java 干货之深入理解String
可以证明,字符串操作是计算机程序设计中最常见的行为,尤其是在Java大展拳脚的Web系统中更是如此. ---<Thinking in Java> 提到Java中的String,总是有说不完 ...
- Go defer使用
defer使用语法 //defer后面必须是函数调用语句或方法调用语句,不能是其他语句,否则编译器会出错. package main import ( "fmt" ) func f ...
- 「2019.8.9 考试」神仙的dp总让人无所适从
T1是个容斥,我掐手指一算他为了卡容斥的正确性,绝不会把n和m出的很相近($O(n^2)$算法在nm相等的时候达到最高时间复杂度),不然就太好做了,于是开了特判+各种卡常和滚动数组优化,卡到了70分, ...
- NOIP模拟 5
考试的时候相当浮躁,而且脑子并不工作 T1看了几眼,觉得没思路,先skip T2一打眼,满足条件的最大值,二分!(然后就死了,根本没想有没有单调性) T3找了半天规律,一开始自己手模的K3都过不了样例 ...
- MySQL 语句执行过程详解
MySQL 原理篇 MySQL 索引机制 MySQL 体系结构及存储引擎 MySQL 语句执行过程详解 MySQL 执行计划详解 MySQL InnoDB 缓冲池 MySQL InnoDB 事务 My ...
- 域名解析 | A记录 ,CNAME,MX,NS 你懂了吗
域名解析 | A记录 ,CNAME,MX,NS 你懂了吗 域名解析 什么是域名解析?域名解析就是国际域名或者国内域名以及中文域名等域名申请后做的到IP地址的转换过程.IP地址是网路上标识您站点的数字地 ...
- 《计算机网络 自顶向下方法》 第3章 运输层 Part1
由于个人精力和智商有限,又喜欢想太多.钻牛角尖,导致学习系统性知识很痛苦,尝试改变学习方式,慢慢摸索 现在看到 rdt2.0,又有点看不下去 现在的想法: 要有个目标,且有截止时间(作业模式.考试模式 ...