字符串的全排列

输入一个字符串,打印该字符串的所有排列。

可以返回任意的字符串数组,但不能有重复元素。

递归:

class Solution
{
   public:
   vector<string> permutation(string s)
   {
       set<string> res;
       permutation(s,0,res);
       return vector<string>(res.begin(),res.end());
   }
   void  permutation(string s, int begin ,set<string>& ans)
   {
       if(begin==s.size()) ans.insert(s);//找到一个全排列记录下来
       for(int i=begin;i!=s.size();i++)
       {
          swap(s[i],s[begin]);//把i换到第一位
          permutation(s,begin+1,ans);//剩余部分全排列
          swap(s[i],s[begin]);//归位
       }
   }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值