全排列

#include <stdio.h>  

int n = 0;  

void swap(int *a, int *b) 
 {     
     int m;     
     m = *a;     
     *a = *b;     
     *b = m; 
 }  
void perm(int list[], int k, int m) 
 {     
     int i;     
     if(k > m)     
     {          
         for(i = 0; i <= m; i++)             
             printf("%c ", list[i]);         
         printf("\n");         
         n++;     
     }     
     else     
     {         
         for(i = k; i <= m; i++)         
         {             
             swap(&list[k], &list[i]);             
             perm(list, k + 1, m);             
             swap(&list[k], &list[i]);         
         }     
     } 
 } 
int main() 
 {     
     int list[] = {'A', 'B', 'C', 'D', 'E'};     
     perm(list, 0, 4);     
     printf("total:%d\n", n);     
     return 0; 
 } 


發佈了46 篇原創文章 · 獲贊 0 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章