算法设计——枚举法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法设计——枚举法相关的知识,希望对你有一定的参考价值。

算法上机课,要我们用枚举法求解。

1. 由0到4五个数字,组成5位数,每个数字用一次,但十位和百位不能为3(当然万位不能为0),输出所有可能的五位数。

我用的是C语言,visualC++编写的


#include<stdio.h>

int main()

{

int i,j,k,m,n;

int count=0;

for(i=1;i<=4;i++){

for(j=0;j<=4;j++){

if(j==i)

continue;

for(k=0;k<=4;k++){

if(k==3||k==i||k==j)

continue;

for(m=0;m<=4;m++){

if(m==3||m==i||m==j||m==k)

continue;

for(n=0;n<=4;n++){

if(n==i||n==j||n==k||n==m)

continue;

printf("%d\n",i*10000+j*1000+k*100+m)

}

}

 }

}

}  


return 0;


}



以上是关于算法设计——枚举法的主要内容,如果未能解决你的问题,请参考以下文章

程序设计与算法算法基础》《第一周 枚举》熄灯问题 POJ-1222

算法研讨会-含有回溯的递归算法设计探讨

算法常用设计模式(子博客)

算法设计-枚举分治素数约数质因数分解

1-5算法设计常用思想之穷举法

程序设计与算法