剑指Offer- 字符串的排列

题目描述 [字符串的排列]

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

输入描述:

输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。

解题思路

  • 深度优先搜索,当序列中的元素不重复时,存在 n! 种不同的排列;
  • 考虑第一个位置,有 n 种可能
  • 当选定了第一个位置,第二个位置有 n-1 种可能
  • 因为每次搜索的状态数是递减的,所以这里的 dfs 是一个循环递归的过程

代码

class Solution {
public:
    void Permutation(vector<string> &res, string &str, int low, int high) {
        if(low==high) res.push_back(str);

        for(int i=low;i<=high;i++){
            if(i!=low && str[i]==str[low]) continue;
            swap(str[i], str[low]);
            Permutation(res, str, low+1, high);
            swap(str[i], str[low]);
        }
    }

    vector<string> Permutation(string str) {
        vector<string> res;
        if(str.size()==0) return res;
        Permutation(res, str, 0, str.size()-1);
        sort(res.begin(), res.end());
        return res;
    }
};
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 写在前面: 最近遇到了一道题涉及全排列的。记得之前在《剑指offer》上遇到了一道类似的题。因此今早把这道题翻了出...
    BlueSkyBlue阅读 691评论 0 0
  • 本文首发于我的个人博客:尾尾部落 题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串...
    繁著阅读 533评论 1 2
  • 题目描述:输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所...
    大数据Zone阅读 369评论 0 1
  • 题目:输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排...
    Kur1ko丶阅读 212评论 0 0
  • 题目:输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排...
    qming_c阅读 503评论 0 0

友情链接更多精彩内容