码迷,mamicode.com
首页 > 其他好文 > 详细

字符串的排列

时间:2017-08-06 12:36:11      阅读:108      评论:0      收藏:0      [点我收藏+]

标签:wap   pre   color   ios   iostream   log   第一个字符   排序   using   

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

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

思路:

把一个字符串看成两部分组成:第一部分为第一个字符,第二部分为后面的所有字符。

求整个字符串的排列,可以看出两步:首先求所有可能出现在第一个位置的字符,即把第一个字符和后面的所有字符交换;然后固定第一个字符,求后面所有字符的排序。此时仍把后面的字符看成两部分,第一个字符和后面的字符,然后重复上述步骤。(递归)

#include <iostream>

using namespace std;

void p2(char *a,char *cur)
{
    if(*cur==\0)
        cout<<a<<\n;
    else{
        for(char *p=cur;*p!=\0;p++)
        {
            swap(*p,*cur);
            p2(a,cur+1);
            swap(*p,*cur);
        }
    }
}

void p1(char *a)
{
    if(a==NULL)
        return;
    p2(a,a);
}
int main()
{
    char a[]="abc";
    p1(a);
    return 0;
}

 

字符串的排列

标签:wap   pre   color   ios   iostream   log   第一个字符   排序   using   

原文地址:http://www.cnblogs.com/home123/p/7291902.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!