淺談c語(yǔ)言中一種典型的排列組合算法
c語(yǔ)言中的全排列算法和組合數(shù)算法在實(shí)際問(wèn)題中應(yīng)用非常之廣,但算法有許許多多,而我個(gè)人認(rèn)為方法不必記太多,最好只記熟一種即可,一招鮮亦可吃遍天
全排列:
#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語(yǔ)言中一種典型的排列組合算法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解vs2022創(chuàng)建及調(diào)用.lib的方法
這篇文章主要介紹了vs2022創(chuàng)建及調(diào)用.lib的方法,調(diào)用Lib的原則就是可以讓編譯器找到頭文件和庫(kù)文件的目錄,并正確引入,本文給大家詳細(xì)講解需要的朋友可以參考下2022-11-11
C/C++字符串與數(shù)字互轉(zhuǎn)的實(shí)現(xiàn)
這篇文章主要介紹了C/C++字符串與數(shù)字互轉(zhuǎn)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
一文帶你了解C++中的右值引用與移動(dòng)語(yǔ)義
本篇文章主要為大家詳細(xì)介紹了C++中的右值引用與移動(dòng)語(yǔ)義的相關(guān)知識(shí),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2023-03-03
C語(yǔ)言每日練習(xí)之動(dòng)態(tài)顯示系統(tǒng)時(shí)間
這篇文章主要介紹了C語(yǔ)言動(dòng)態(tài)顯示系統(tǒng)時(shí),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-11-11
C++中求旋轉(zhuǎn)數(shù)組中的最小數(shù)字(經(jīng)典面試題)
這篇文章主要介紹了C++中求旋轉(zhuǎn)數(shù)組中的最小數(shù)字(經(jīng)典面試題)的相關(guān)資料,需要的朋友可以參考下2017-03-03
C語(yǔ)言堆與二叉樹(shù)的順序結(jié)構(gòu)與實(shí)現(xiàn)
堆是計(jì)算機(jī)科學(xué)中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱,通常是一個(gè)可以被看做一棵完全二叉樹(shù)的數(shù)組對(duì)象。而堆排序是利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計(jì)的一種排序算法。本文將詳細(xì)介紹堆與二叉樹(shù)的順序結(jié)構(gòu)與實(shí)現(xiàn),需要的可以參考一下2022-05-05
C++實(shí)現(xiàn)簡(jiǎn)單的HTTP服務(wù)器
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單的HTTP服務(wù)器的相關(guān)資料,感興趣的朋友可以參考下2016-05-05

