枚举

作者: Day_Winston | 来源:发表于2018-01-11 21:15 被阅读6次

枚举

  • 枚举算法又叫穷举算法。 基本思想是“有序地去尝试每一种可能”。
    例子:□□□+□□□=□□□,将数字1~9分别填入9个□中,每个数字只能使用一次使得等式成立,求出有多少种组合,注意其中173+286=459与286+173=459是同一种组合。
#include<stdio.h>
int main()
{
    int a, b, c, d, e, f, g, h, i, total = 0;
    for(a = 1; a <= 9; a++)
        for(b = 1; b <= 9; b++)
            for(c = 1; c <= 9; c++)
                for(d = 1; d <= 9; d++)
                    for(e = 1; e <= 9; e++)
                        for(f = 1; f <= 9; f++)
                            for(g = 1; g <= 9; g++)
                                for(h = 1; h <= 9; h++)
                                    for(i = 1; i <= 9; i++)
                                    {
                                        if(a != b && a != c && a != d && a != e && a != f && a != g && a != h && a != i
                                                && b != c && b != d && b != e && b != f && b != g && b != h && b != i
                                                && c != d && c != e && c != f && c != g && c != h && c != i
                                                && d != e && d != f && d != g && d != h && d != i
                                                && e != f && e != g && e != h && e != i
                                                && f != g && f != h && f != i
                                                && g != h && g != i
                                                && h != i
                                                && a * 100 + b * 10 + c + d * 100 + e * 10 + f == g * 100 + h * 10 + i)
                                        {
                                            total++;
                                            printf("%d%d%d+%d%d%d=%d%d%d\n", a, b, c, d, e, f, g, h, i);
                                        }
                                    }
    printf("total = %d", total / 2);
    getchar();getchar();
    return 0;
}
/*输出结果:total = 168*/

代码是不是很长,想想办法精减一下。


枚举2

  • 用数组的方法解决,但是代码依然亢长。
#include<stdio.h>
int main()
{
    int a[10], i, total = 0, book[10], sum;
    for(a[1] = 1; a[1] <= 9; a[1]++)
        for(a[2] = 1; a[2] <= 9; a[2]++)
            for(a[3] = 1; a[ 3] <= 9; a[3]++)
                for(a[4] = 1; a[4] <= 9; a[4]++)
                    for(a[5] = 1; a[5] <= 9; a[5]++)
                        for(a[6] = 1; a[6] <= 9; a[6]++)
                            for(a[7] = 1; a[7] <= 9; a[7]++)
                                for(a[8] = 1; a[8] <= 9; a[8]++)
                                    for(a[9] = 1; a[9] <= 9; a[9]++)
                                    {
                                        for(i = 1; i <= 9; i++)
                                            book[i] = 0;
                                        for(i = 1; i <= 9; i++)
                                            book[a[i]] = 1;
                                        sum = 0;
                                        for(i = 1; i <= 9; i++)
                                            sum += book[i];

                                        if(sum == 9 && a[1] * 100 + a[2] * 10 + a[3] + a[4] * 100 + a[5] * 10 + a[6] == a[7] * 100 + a[8] * 10 + a[9])
                                        {
                                            total++;
                                            printf("%d%d%d+%d%d%d=%d%d%d\n", a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8], a[9]);
                                        }
                                    }
    printf("total = %d", total / 2);
    getchar();getchar();
    return 0;
}
/*输出结果:total = 168;*/

相关文章

  • C#枚举及与枚举常数的转换

    1、枚举的定义 2、枚举绑定到comboBox 3、枚举常数转换为枚举string转枚举 数字值转枚举

  • Swift 基础笔记 - 枚举

    枚举 OC定义和使用枚举 Swift定义枚举类型 Swift判断枚举类型 枚举成员类型

  • 枚举类

    1.枚举类型的定义: 枚举类型定义的一般形式为 enum 枚举名{//枚举值表枚举值1;枚举值2;...} 在枚举...

  • 10、枚举与闭包

    枚举 枚举和普通类相比有什么优势 枚举类型、枚举名称与枚举值 枚举的比较运算 两个枚举之间可以使用等值比较(==)...

  • Swift与OC的语法简单对比(常用语法二)

    20- 枚举,枚举原始值,枚举相关值,switch提取枚举关联值 Swift枚举: Swift中的枚举比OC中的枚...

  • Swift 2 学习笔记 10.枚举

    课程来自慕课网liuyubobobo老师 枚举 枚举基础 枚举之原始值 枚举之关联值 枚举递归

  • swift3语法(八)

    枚举/结构体 枚举 定义形式enum 枚举名 { 枚举值} // 例如enum CompassPoint {...

  • C语言基础 之 枚举类型

    枚举类型 枚举类型: 列出所有可能的值 枚举类型的定义 枚举类型定义的一般格式:enum 枚举类型名 {枚举值表}...

  • 枚举

    枚举 Why:为什么需要枚举 What:枚举是什么; How:枚举怎么实现 When:枚举什么时候使用 Where...

  • 枚举的概念及应用

    一、枚举的概念 二、枚举类型的定义 三、枚举变量的定义 四、枚举使用的注意 五、枚举变量的基本操作 五、枚举变量的...

网友评论

      本文标题:枚举

      本文链接:https://www.haomeiwen.com/subject/xoitoxtx.html