淺談c語言中一種典型的排列組合算法
c語言中的全排列算法和組合數(shù)算法在實際問題中應用非常之廣,但算法有許許多多,而我個人認為方法不必記太多,最好只記熟一種即可,一招鮮亦可吃遍天
全排列:
#include<stdio.h> void swap(int *p1,int *p2) { int t=*p1; *p1=*p2; *p2=t; } void permutation(int a[],int index,int size) { if(index==size) { for(int i=0;i<size;i++) printf("%d ",a[i]); printf("\n"); } else { for(int j=index;j<size;j++) { swap(&a[j],&a[index]); permutation(a,index+1,size);//此處用到遞歸思想 swap(&a[j],&a[index]); } } } int main() { int n; scanf("%d",&n); int a[n]; for(int i=0;i<n;i++) a[i]=i+1; permutation(a,0,n); return 0; }
組合:
#include<stdio.h> void combine(int n,int m,int a[],int b[],const int M) { for(int j=n;j>=m;j--) { b[m-1]=j-1; if(m>1)combine(j-1,m-1,a,b,M);//用到了遞歸思想 else { for(int i=M-1;i>=0;i--)printf("%d ",a[b[i]]); printf("\n"); } } } int main() { int n,m; scanf("%d%d",&n,&m); int a[n];int b[m]; for(int i=0;i<n;i++) a[i]=i+1; const int M=m; combine(n,m,a,b,M); }
以上這篇淺談c語言中一種典型的排列組合算法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持我們。
上一篇:C++中的const的使用詳解
欄 目:C語言
下一篇:C++使用一個棧實現(xiàn)另一個棧的排序算法示例
本文標題:淺談c語言中一種典型的排列組合算法
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1582.html
您可能感興趣的文章
- 04-02c語言函數(shù)調用后清空內存 c語言調用函數(shù)刪除字符
- 04-02c語言的正則匹配函數(shù) c語言正則表達式函數(shù)庫
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對數(shù)怎么表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段函數(shù)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排序法函數(shù)
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02C語言中怎么打出三角函數(shù) c語言中怎么打出三角函數(shù)的值
- 04-02c語言調用函數(shù)求fibo C語言調用函數(shù)求階乘


閱讀排行
本欄相關
- 04-02c語言函數(shù)調用后清空內存 c語言調用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調用函數(shù)求fibo C語言調用函數(shù)求
隨機閱讀
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10delphi制作wav文件的方法
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10C#中split用法實例總結
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 04-02jquery與jsp,用jquery
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文