全排列

全排列

http://www.nowcoder.com/questionTerminal/5632c23d0d654aecbc9315d1720421c1

思路

递归回溯问题,例如 abc,我们可以在每一次递归的时候把某一个字母放到最前面,就是 swap 一下,就变成了分别从 abc、bac、cba 开始的字符串,然后后面的两个字母也可以选择任意一个放到“开头”,以此类推

#include<iostream>
#include<vector>
#include<algorithm>

using namespace std;

void backtrace(vector<string>& ans, string s, int start, int len){
    if(start == len){
        ans.push_back(s);
        return;
    }
    for(int i = start; i < len; i ++){
        swap(s[i], s[start]);
        backtrace(ans, s, start + 1, len);
        swap(s[i], s[start]);
    }
}
int main(){
    string s;
    while(cin >> s){
        vector<string> ans;
        backtrace(ans, s, 0, s.size());
        sort(ans.begin(), ans.end());
        for(string c : ans)
            cout << c << endl;
    }
    return 0;
}
算法题解 文章被收录于专栏

不定期更新一些算法题解,有什么问题可以随时留言~

全部评论

相关推荐

点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务