标签:style blog http os io ar for art 问题
11111--------abcde
#include <stdio.h> #include <string.h> void printCombination(char* str, int i); void combination(char* str) { int len = strlen(str); //共有(1<<len)个组合,其中有一次什么都不打印外 for(int i=0; i< (1<<len); ++i) { printCombination(str, i); printf("\n"); } } void printCombination(char* str, int i) { int len = strlen(str); for(int j=0; j<len; ++j) { //看s中哪些位为 int s = i&(1<<j); if(s) printf("%c", str[j]); } } int main() { char str[] = "abc"; combination(str); }
#include <stdio.h> #include <string.h> void printCombination(char* str, int len, int m, int* arr, const int M); void combination(char* str) { int len = strlen(str); int* arr = new int[len]; for(int i=1; i<=len; ++i) { printCombination(str, len, i, arr, i); } delete[] arr; } //从n中选m个数进行组合 /************************************** a. 首先从n个数中选取编号最大的数,然后在剩下的n-1个数里面选取m-1个数, 直到从n-(m-1)个数中选取个数为止。 b. 从n个数中选取编号次小的一个数,继续执行步,直到当前可选编号最大的数为m。 ******************************************/ void printCombination(char* str, int len, int m, int* arr, const int M) { for(int i=len; i>=m;--i) { //依次选择编号最大的数,次大的数.... arr[m-1] = i-1; if(m>1) { //选择的数目大于,从剩余的i-1个数中选取m-1个数的组合 printCombination(str,i-1,m-1,arr,M); } else { //打印M个数字 for(int j=M-1; j>=0; --j) { printf("%c ", str[arr[j]]); } printf("\n"); } } } int main() { char str[] = "abcd"; combination(str); return 0; }
实现代码如下:
#include <stdio.h> #include <stdlib.h> #include <string.h> int l=0; //function definition void composition(const char [],int,int); void printCompostion(const char[],const bool[],int); //function implementation void printCompostion(const char source[],const bool comp[],int n){ int i; for (i=0;i<n;i++) if (comp[i]==true) printf ("%c-",source[i]); printf ("\n"); } void compostion(const char* source,int n,int m){ bool * comp = (bool*)malloc(n*sizeof(bool)); int i; for (i=0;i<m;i++) comp[i]=true; for (i=m;i<n;i++) comp[i]=false; printCompostion(source,comp,n); l++; while(true){ for (i=0;i<n-1;i++) if (comp[i]==true&&comp[i+1]==false) break; if (i==n-1) return; //all the compostion is found out comp[i]=false; comp[i+1]=true; int p=0; while (p<i){ while (comp[p]==true) p++; while (comp[i]==false) i--; if (p<i) { comp[p]=true; comp[i]=false; } } printCompostion(source,comp,n); l++; } } //test function void testCompostion(){ char* testcase = "abcdefghijklmno"; int n=strlen(testcase); int m=7; compostion(testcase,n,m); } //main function void main(){ testCompostion(); printf ("total=%d\n",l); }
#include <stdio.h> #include <string.h> #include <stdlib.h> #define LENGTH 27 int n=0; void permute(int[],int,int); void swapint(int &a,int &b); void printIntArray (int[],int); //Function Implementation void swapint(int &a,int &b){ int temp; temp = a; a = b; b = temp; } void printIntArray(int target[],int length){ int i; for (i=0;i<length;i++) printf ("%d",target[i]); printf ("\n"); } void permute(int target[],int begin,int end){ if (begin==end) { printIntArray(target,end+1); n++; return; } int i; for (i=begin;i<=end;i++){ swapint(target[begin],target[i]); permute(target,begin+1,end); swapint(target[begin],target[i]); } } //test Functions void testPermute(){ int len; scanf ("%d",&len); int *testcase =(int *)malloc(len*sizeof(int)); int i; for (i=0;i<len;i++) testcase[i]=i+1; permute(testcase,0,len-1); } //Main Function void main(){ testPermute(); printf ("n=%d",n); }
#include "iostream" #include "algorithm" using namespace std; void permutation(char* str,int length) { sort(str,str+length); //必须得先排序 do { for(int i=0;i<length;i++) cout<<str[i]; cout<<endl; }while(next_permutation(str,str+length)); } int main(void) { char str[] = "acb"; cout<<str<<"所有全排列的结果为:"<<endl; permutation(str,3); system("pause"); return 0; }
其中next_permutation()的实现如下:
template<class BidirectionlIterator> bool next_permutation(BidirectionalIterator firt, BidirectionalIterator last) { if(first == last) return false; //空区间 BidirectionalIterator i = first; ++i; if(i == last) return false; //只有一个元素 i = last; //i指向尾端 --i; for(;;){ BidrectionalIterator ii = i; --i; //以上,锁定一组(两个)相邻元素 if(*i < *ii) //如果前一个元素小于后一个元素 { BidrectionalIterator j = last; //令j指向尾端 while(!(*i < *--j)); //由尾端往前找,直到遇上比*i大的元素 iter_swap(i,j); //交换i,j reverse(ii, last); //将ii之后的元素全部逆向重排 return true; } if(i == first) //进行到最前面了 { reverse(first, last); //全部逆向重置 return false; } } }
#include <stdio.h> #include <algorithm> #include <string.h> using namespace std; //反转数组 void reverse(char* str, int first, int last) { if(str == NULL || *str == '\0') return; while(first < last) { char ch = str[first]; str[first] = str[last]; str[last] = ch; first++; last--; } } //打印数组 void printfString(char* str) { for(int i=0; i<strlen(str); ++i) { printf("%c", str[i]); } printf("\n"); } //找到下一个数组 bool next_permutation(char* str) { if(str == NULL || *str=='\0') return false; int len = strlen(str); int i = len - 2; int ii = i+1; int j = len - 1; //从后端开始找到第一对str[i]<str[j]的数字 while(str[i] > str[ii]) { --i; --ii; //如果i<0,则表示已经全部排列 if(i<0) { //全部翻转 reverse(str, i+1, len-1); return false; } } //从后面找到第一个大于str[i]的数字 while(str[j] < str[i]) { --j; } //交换 char ch = str[i]; str[i] = str[j]; str[j] = ch; //翻转j之后的数组 reverse(str, ii, len-1); return true; } int main() { char str[] = "cab"; int len = strlen(str); //必须先排序 sort(str, str + len); printfString(str); //打印全排列 while(next_permutation(str)) { printfString(str); } return 0; }
参见:
http://blog.csdn.net/hackbuteer1/article/details/7462447
http://xiaomage.blog.51cto.com/293990/74094
http://blog.csdn.net/hackbuteer1/article/details/6657435
标签:style blog http os io ar for art 问题
原文地址:http://blog.csdn.net/walkerkalr/article/details/39049377