枚举法

简介: 枚举法
/**
口袋里有红、黄、蓝、白、黒5种颜色的球若干,每次从口袋中先后取出3个球,问得到3种不同颜色的
球的可能取法,输出每种排列的情况
**/
#include <stdio.h>
#include <stdlib.h>
int main()
{
    enum Color {red,yellow,blue,white,black};
    enum Color i,j,k,pri;
    int n,loop;
    n=0;
    for(i=red;i<=black;i++)
        for(j=red;j<=black;j++)
    {
        if(i!=j)
        {
            for(k=red;k<=black;k++)
            {
                if((k!=i)&&(k!=j))
                {
                    n++;
                    printf("%-4d",n);
                    for(loop=1;loop<=3;loop++)
                    {
                        switch(loop)
                        {
                            case 1:pri=i;break;
                            case 2:pri=j;break;
                            case 3:pri=k;break;
                            default :break;
                        }
                        switch(pri)
                        {
                            case red:printf("%-10s","red");break;
                            case yellow:printf("%-10s","yellow");break;
                            case blue:printf("%-10s","blue");break;
                            case white:printf("%-10s","white");break;
                            case black:printf("%-10s","black");break;
//不能用printf("%s",red);来输出“red”字符串。
//必须打上引号。
                            default :break;
                        }
                    }
                    putchar('\n');
                }
            }
        }
    }
    printf("\ntotal:%5d\n",n);
    return 0;
}


这个题完全可以用常量1-5来代替颜色,

但这样写更直观,不是吗!

目录
相关文章
|
8月前
|
算法 测试技术 C++
【数学归纳法 组合数学】容斥原理
【数学归纳法 组合数学】容斥原理
|
机器学习/深度学习 算法
算法提高:组合数学| 卡特兰数的实现
卡特兰数列是组合数学中在各种计数问题中常出现的数列,其前几项为1,1,2,5,14,42,132,429,1430,4862,16796,58786,208012…… 卡特兰数首先是由欧拉在计算对凸n边形的不同的对角三角形剖分的个数问题时得到的,即在一个凸n边形中,通过不相交于n边形内部的对角线,把n边形拆分成若干三角形,不同的拆分数用Hn表示,Hn即卡特兰数。
156 0
算法提高:组合数学| 卡特兰数的实现
|
存储
欧拉筛&&埃氏筛
欧拉筛&&埃氏筛
106 0
枚举法
列举问题的所有可能的答案,然后根据条件判断此答案是否合适,合适就保留,不合适就丢弃。 逐一列举问题所涉及的所有情形,并根据问题提出的条件检验哪些是问题的解,哪些应予排除。
276 0
枚举法
|
存储 缓存 移动开发
动态规划法
动态规划是在20世纪50年代由美国数学家贝尔曼为研究最优控制问题而提出的,当该方法在应用数学中的价值被大家认同以后,在计算机学界,动态规划法成为一种通用的算法设计技术用来求解多阶段决策最优化问题。
|
缓存 算法 网络协议
贪心法
贪心法是把一个复杂问题分解为一系列较为简单的局部最优选择,每一步选择都是对当前解的一个扩展,直到获得问题的完整解。贪心法的典型应用是求解最优化问题,而且对许多问题都能得到整体最优解,即使不能得到整体最优解,通常也是最优解的很好近似。
|
算法
【贪心法】会场安排问题
【贪心法】会场安排问题
267 0
|
算法
数学知识:求组合数(二)
复习acwing算法基础课的内容,本篇为讲解数学知识:求组合数,关于时间复杂度:目前博主不太会计算,先鸽了,日后一定补上。
143 0
数学知识:求组合数(二)
|
算法
数学知识:求组合数(一)
复习acwing算法基础课的内容,本篇为讲解数学知识:求组合数,关于时间复杂度:目前博主不太会计算,先鸽了,日后一定补上。
151 0
数学知识:求组合数(一)
|
算法
数学知识:求组合数(三)
复习acwing算法基础课的内容,本篇为讲解数学知识:求组合数,关于时间复杂度:目前博主不太会计算,先鸽了,日后一定补上。
133 0
数学知识:求组合数(三)