题目:

输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。

输入描述:

  1. 输入一个字符串,长度不超过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++

  1. class Solution {
  2. public:
  3. vector<string> Permutation(string str) {
  4. if(str.size() == )
  5. return res;
  6. helper(str, );
  7. for(auto i:tempRes)
  8. res.push_back(i);
  9. return res;
  10. }
  11. void helper(string str, int index){
  12. if(index == str.size()-)
  13. //res.push_back(str);
  14. tempRes.insert(str);
  15. for(int i = index; i < str.size(); ++i){
  16. swap(str[index], str[i]);
  17. helper(str, index+);
  18. }
  19. }
  20. vector<string> res;
  21. set<string> tempRes;
  22. };
  1. class Solution {
  2. public:
  3. vector<string> Permutation(string str) {
  4. if(str.size() == )
  5. return res;
  6. res.push_back(str.substr(, ));
  7. strSet.insert(str.substr(, ));
  8. for(int i = ; i < str.size(); ++i){
  9. int m = res.size();
  10. for(int j = ; j < m; ++j){
  11. string tempStr = res.back();
  12. res.pop_back();
  13. for(int k = ; k <= tempStr.size(); ++k){
  14. string ttempStr = tempStr;
  15. ttempStr.insert(k, str.substr(i,));
  16. set<string>::iterator iter;
  17. if((iter = strSet.find(ttempStr)) == strSet.end()){
  18. res.insert(res.begin(), ttempStr);
  19. strSet.insert(ttempStr);
  20. }
  21. }
  22. }
  23. }
  24. sort(res.begin(), res.end());
  25. return res;
  26. }
  27. private:
  28. set<string> strSet;
  29. vector<string> res;
  30. };

Java

  1. import java.util.ArrayList;
  2. import java.util.Collections;
  3. //import java.util.HashSet;
  4. public class Solution {
  5. public ArrayList<String> Permutation(String str) {
  6. if(str.length() == 0)
  7. return res;
  8. StringBuilder s = new StringBuilder(str);
  9. Helper(s, 0);
  10. Collections.sort(res);
  11. return res;
  12. }
  13. public void Helper(StringBuilder s, int index){
  14. if(index == s.length()-1)
  15. res.add(s.toString());
  16. for(int i = index; i < s.length(); ++i){
  17. if(s.charAt(index) != s.charAt(i) || index == i){
  18. Swap(s, index, i);
  19. Helper(s, index+1);
  20. Swap(s, index, i);
  21. }
  22. }
  23. }
  24. public static void Swap(StringBuilder s, int i, int j) {
  25. char temp = s.charAt(i);
  26. s.setCharAt(i, s.charAt(j));
  27. s.setCharAt(j, temp);
  28. }
  29. private ArrayList<String> res = new ArrayList<>();
  30. //private HashSet<String> set = new HashSet<>();
  31. }

剑指Offer-27.字符串的排列(C++/Java)的更多相关文章

  1. 剑指Offer 27. 字符串的排列 (字符串)

    题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入描述: 输 ...

  2. [剑指Offer] 27.字符串的排列

    [思路]从第一位开始,判断每一位字符的所有可能性,依此递归. class Solution { public: void PermutationHelp(vector<string> &a ...

  3. 剑指 Offer 38. 字符串的排列 + 无重复元素的全排列

    剑指 Offer 38. 字符串的排列 Offer_38 题目描述 解题思路 可以使用递归实现全排列,每次都确定一个数的位置,当所有位置的数都确定后即表示一个排列. 但是考虑到本题需要排除重复的排列, ...

  4. 剑指 Offer 38. 字符串的排列

    剑指 Offer 38. 字符串的排列 输入一个字符串,打印出该字符串中字符的所有排列. 你可以以任意顺序返回这个字符串数组,但里面不能有重复元素. 示例: 输入:s = "abc" ...

  5. 【剑指Offer】字符串的排列 解题报告(Python)

    [剑指Offer]字符串的排列 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https://www.nowcoder.com/ta/coding-interviews 题 ...

  6. 【Java】 剑指offer(38) 字符串的排列

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 输入一个字符串,打印出该字符串中字符的所有排列.例如输入字符串ab ...

  7. Go语言实现:【剑指offer】字符串的排列

    该题目来源于牛客网<剑指offer>专题. 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,b ...

  8. 《剑指offer》字符串的排列

    本题来自<剑指offer> 反转链表 题目: 思路: C++ Code: Python Code: 总结:

  9. 剑指offer:字符串的排列

    题目描述: 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入描述: ...

  10. 剑指OFFER之字符串的排列(九度OJ1369)

    题目描述: 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入: 每个 ...

随机推荐

  1. Java 根据权重获取数据 基础 极简 准确率高

    package sl; import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.ut ...

  2. 使用 pdf.js 跨域问题的处理方法1

    在<使用 pdf.js 在网页中加载 pdf 文件>中详细介绍了 pdf.js 的使用与集成网页开发的基本方法.展示效果如下图: 站点的目录为 http://localhost:8033/ ...

  3. GO基础之List

    一.List定义 概述1.list是一种非连续存储的容器,由多个节点组成,节点通过一些变量记录彼此之间的关系.list有多种实现方法,如单向链表.双向链表等.2.Go语言中list的实现原理是双向链表 ...

  4. 【重构】AndroidStudio中代码重构菜单Refactor功能详解

    代码重构几乎是每个程序员在软件开发中必须要不断去做的事情,以此来不断提高代码的质量.Android Stido(以下简称AS)以其强大的功能,成为当下Android开发工程师最受欢迎的开发工具,也是A ...

  5. 从比特币、以太坊、libra的不同特点认识move语言

    关于比特币.以太坊.libra,我们知道他们是不同的区块链应用,那么他们的根本差别在哪里呢. 其实,单从白皮书的标题,就可以大概看出三个项目在设计目标上的差异. 比特币的目标是 -- 可编程货币(Pr ...

  6. Linux 命令行获取天气

    目标: 使用 Linux 命令行显示天气预报. 发行版: 所有 Linux 发行版. 要求: 能连上因特网的 Linux 难度: 容易 约定: # - 需要使用 root 权限来执行指定命令,可以直接 ...

  7. Django学习day8——admin后台管理和语言适应

    Django最大的优点之一,就是体贴的为你提供了一个基于项目model创建的一个后台管理站点admin.这个界面只给站点管理员使用,并不对大众开放. 1. 创建管理员用户 (django) E:\Dj ...

  8. 基于Rancher搭建Kubernetes

    基于Rancher搭建Kubernetes可以大大的简化安装的步骤,直接安装Kubernetes操作复杂并且容易出错. 转自 https://blog.csdn.net/u011142688/arti ...

  9. Java Part 001( 01_01_Java概述 )

    Java作为编程语言, 甚至超出了语言的范畴, 成为一种开发平台, 一种开发规范. Java语言相关的JavaEE规范里, 包含了时下最流行的各种软件工程理念, 学习Java相当于系统的学习了软件开发 ...

  10. 「分治」-cdq分治

    cdq分治是一种分治算法: 一种分治思想,必须离线,可以用来处理序列上的问题(比如偏序问题),还可以优化1D/1D类型的DP.• 算法的大体思路我们可以用点对来描述.假定我们有一个长度为n的序列,要处 ...