标签: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