排列和組合算法的實現(xiàn)方法_C語言經典案例
排列和組合算法是考查遞歸的常見算法,這兩種算法能用遞歸簡潔地實現(xiàn)。
本人在經過多次摸索和思考之后,總結如下,以供參考。
程序代碼如下:
#include <stdio.h>
#include <stdlib.h>
char array[] = "abcd";
#define N 4
#define M 3
int queue[N] = {0};
int top = 0;
int flag[N] = {0};
void perm(int s, int n)
{
int i;
if (s > n)
{
return;
}
if (s == n)
{
for (i = 0; i < n; i++)
{
printf("%c", queue[i]);
}
printf("\t");
return ;
}
for (i = 0; i < n; i++)
{
if (flag[i] == 0)
{
flag[i] = 1;
queue[s] = array[i];
perm(s+1, n);
flag[i] = 0;
}
}
}
void comb(int s, int n, int m)
{
int i;
if (s > n)
return ;
if (top == m)
{
for (i = 0; i < m; i++)
{
printf("%c", queue[i]);
}
printf("\t");
return ;
}
queue[top++] = array[s];
comb(s+1, n, m);
top--;
comb(s+1, n, m);
}
int main()
{
printf("\nperm():\n");
perm(0, N);
printf("\ncombination():\n");
comb(0, N, M);
printf("\n");
return 0;
}
運行結果:
perm(): abcd abdc acbd acdb adbc adcb bacd badc bcad bcda bdac bdca cabd cadb cbad cbda cdab cdba dabc dacb dbac dbca dcab dcba combination(): abc abd acd bcd
以上就是小編為大家?guī)淼呐帕泻徒M合算法的實現(xiàn)方法_C語言經典案例的全部內容了,希望對大家有所幫助,多多支持我們~
上一篇:C語言之雙向鏈表詳解及實例代碼
欄 目:C語言
下一篇:C/C++字符串查找函數全面了解
本文標題:排列和組合算法的實現(xiàn)方法_C語言經典案例
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/2048.html
您可能感興趣的文章
- 01-10求子數組最大和的解決方法詳解
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10深入全排列算法及其實現(xiàn)方法
- 01-10全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)
- 01-10用C實現(xiàn)添加和讀取配置文件函數
- 01-10深入串的模式匹配算法(普通算法和KMP算法)的詳解
- 01-10如何求連續(xù)幾個數之和的最大值
- 01-10如何在二叉樹中找出和為某一值的所有路徑
- 01-10用代碼和UML圖化解設計模式之橋接模式的深入分析
- 01-10C語言中字符串和數字的相互轉換實現(xiàn)代碼


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


