概述
题目描述
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则按字典序打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
输入描述:
输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。
牛客网题目链接
解题思路
需要两步即可解决问题:
- 把第一个字符和后面所有的字符交换
- 固定第一个字符,求后面字符的排列
代码实现
using namespace std;
class Solution {
public:
vector<string> Permutation(string str) {
vector <string> res;
if(!str.size())return res;
else{
char arr[str.size()];
for(int i=0;i<str.size();i++)arr[i]=str[i];
arr[str.size()]='