热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

《24点游戏》

《编程之美》1.16节《24点游戏》,这个不多说了,大家从小玩到大的。书中解法一用了枚举的方法,依次求解出所有7680种表达式的值

 《编程之美》1.16节《24点游戏》,这个不多说了,大家从小玩到大的。书中解法一用了枚举的方法,依次求解出所有7680种表达式的值;解法二用了分治的思想来优化算法,我写的算法就是根据解法二来的,书中的伪代码只能判断N个数能否求出24,而我改进之后就可以输出满足题意的表达式了

  算法中我用到C++ STL中的set容器,因为set中的元素都是非重的。

//实现N个数通过简单的运算得到结果24.

CODE

//24Game
//2010-01-17
//by roovent

#include
#include
#include
#include
#define N 4
#define M (1<#define TARGET 24

using namespace std;

struct Element
{
    double num;
    string expression;

    friend bool operator<(const Element& a, const Element& b)
    {
        return a.num     }
};

//--全局变量
set result[M];
//--全局变量结束

set Process(const int x, int* nums)
{
    set s;
    for(int i &#61; 1; i     {  
        if((i|x) &#61;&#61; x && x-i>i) //i是x的子集&#xff0c;x-i是其补集&#xff0c;确保子集与其补集不重复运算
        {
            for(set::iterator p &#61; result[i].begin(); p !&#61; result[i].end(); &#43;&#43;p)
            {
                for(set::iterator q &#61; result[x-i].begin(); q !&#61; result[x-i].end(); &#43;&#43;q)
                {
                    Element e;
                    double dbA &#61; (*p).num;
                    double dbB &#61; (*q).num;
                    string strA &#61; (*p).expression;
                    string strB &#61; (*q).expression;

                    e.num &#61; dbA &#43; dbB;
                    e.expression &#61; "(" &#43; strA &#43; " &#43; " &#43; strB &#43; ")";
                    s.insert(e);

                    e.num &#61; dbA - dbB;
                    e.expression &#61; "(" &#43; strA &#43; " - " &#43; strB &#43; ")";
                    s.insert(e);

                    e.num &#61; dbB - dbA;
                    e.expression &#61; "(" &#43; strB &#43; " - " &#43; strA &#43; ")";
                    s.insert(e);

                    e.num &#61; dbA * dbB;
                    e.expression &#61; "(" &#43; strA &#43; " * " &#43; strB &#43; ")";
                    s.insert(e);
                   
                    if(dbB !&#61; 0)
                    {
                        e.num &#61; dbA / dbB;
                        e.expression &#61; "(" &#43; strA &#43; " / " &#43; strB &#43; ")";
                        s.insert(e);
                    }
                   
                    if(dbA !&#61; 0)
                    {
                        e.num &#61; dbB / dbA;
                        e.expression &#61; "(" &#43; strB &#43; " / " &#43; strA &#43; ")";
                        s.insert(e);
                    }
                }
            }
        }
    }
    return s;
}

bool Solve(int* nums)
{
    for(int i &#61; 0; i     {
        result[i].clear();
    }

    for(int i &#61; 0; i     {
        stringstream ss;
        ss<        Element e &#61; {nums[i], ss.str()};
        result[1<    }

    for(int i &#61; 1; i     {
        if(result[i].empty())
            result[i] &#61; Process(i, nums);
    }

    Element e &#61; {TARGET, ""};
    return result[M-1].find(e) !&#61; result[M-1].end();
}

int main()
{
    int nums[N] &#61;
        {5,5,5,1};
        //{3,3,7,7};
        //{3,3,8,8};
        //{1,4,5,6};
        //{3,8,8,10};
        //{4,4,10,10};
        //{9,9,6,2};
   
    cout<<"Problem: ";
    for(int i &#61; 0; i     {
        cout<    }
    cout<

    if(Solve(nums))
    {
        Element e &#61; {TARGET, ""};
        cout<<"Solution: "<<(*(result[M-1].find(e))).expression <    }
    else
    {
        cout<<"No Solution"<    }
    return 0;
}


推荐阅读
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • c语言\n不换行,c语言printf不换行
    本文目录一览:1、C语言不换行输入2、c语言的 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了Java的集合及其实现类,包括数据结构、抽象类和具体实现类的关系,详细介绍了List接口及其实现类ArrayList的基本操作和特点。文章通过提供相关参考文档和链接,帮助读者更好地理解和使用Java的集合类。 ... [详细]
  • C++中的三角函数计算及其应用
    本文介绍了C++中的三角函数的计算方法和应用,包括计算余弦、正弦、正切值以及反三角函数求对应的弧度制角度的示例代码。代码中使用了C++的数学库和命名空间,通过赋值和输出语句实现了三角函数的计算和结果显示。通过学习本文,读者可以了解到C++中三角函数的基本用法和应用场景。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • Python SQLAlchemy库的使用方法详解
    本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 如何在跨函数中使用内存?
    本文介绍了在跨函数中使用内存的方法,包括使用指针变量、动态分配内存和静态分配内存的区别。通过示例代码说明了如何正确地在不同函数中使用内存,并提醒程序员在使用动态分配内存时要手动释放内存,以防止内存泄漏。 ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
author-avatar
怪物-pp_912
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有