考虑到1.00版本需要改源码变更四个数字,这版修改了一下变成控制台输入了。

先把两个数四则运算得到结果想清楚就是C2代码,三个数就是C3,四个数就是C4.简单的代码简单,却是复杂的基础;复杂的脱胎于简单,但还有自己的特性。

新代码如下:

//======================================================
// 算24 C4 1.01
// 增加控制台输入,避免改源码了
// 2018年4月18日
//======================================================

var micro=0.000001 // 定义一个极小量,运算结果绝对值小于它就算相等

//======================================================
// C2类,用于判断两个数通过加减乘除运算能否得到某个结果
// C代表Caculate,2代表两个操作数
// op1:操作数1,op2:操作数2,result,结果
//======================================================
function C2(op1,op2,result){
    var obj=new Object();
    obj.op1=op1;
    obj.op2=op2;
    obj.result=result;

    obj.findComputationMethods=function(){
        var arr=[];

        if(Math.abs(result-(op1+op2))<micro){
            arr.push(op1+"+"+op2);    // op1+op2
        }

        if(Math.abs(result-op1*op2)<micro){
            arr.push(op1+"*"+op2);    // op1*op2
        }

        if(Math.abs(result-(op1-op2))<micro){
            arr.push(op1+"-"+op2);    // op1-op2
        }

        if(Math.abs(result-(op2-op1))<micro){
            arr.push(op2+"-"+op1);    // op2-op1
        }

        if(Math.abs(result-op1/op2)<micro){
            arr.push(op1+"/"+op2);    // op1/op2
        }

        if(Math.abs(result-op2/op1)<micro){
            arr.push(op2+"/"+op1);    // op2/op1
        }

        return arr;
    }

    return obj;
}

//======================================================
// C3类,用于判断三个数通过加减乘除运算能否得到某个结果
// C代表Caculate,3代表两个操作数
// op1:操作数1,op2:操作数2,op3:操作数3,result,结果
//======================================================
function C3(op1,op2,op3,result){
    var obj=new Object();
    obj.op1=op1;
    obj.op2=op2;
    obj.op3=op3;
    obj.result=result;

    obj.findComputationMethods=function(){
        var retArr=[];// 返回数组

        var permutationArr=[ [this.op1,this.op2,this.op3],
                        [this.op1,this.op3,this.op2],
                        [this.op2,this.op1,this.op3],
                        [this.op2,this.op3,this.op1],
                        [this.op3,this.op2,this.op1],
                        [this.op3,this.op1,this.op2], ]; // 排列数组,三个操作数共有6种排列方式

        for(var i=0;i<permutationArr.length;i++){
            var arr=permutationArr[i];
            var op1=arr[0];
            var op2=arr[1];
            var op3=arr[2];

            var c2=new C2(op1,op2,this.result+op3);
            var methods=c2.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push('('+methods[j]+")"+"-"+op3);// [op1,op2]-op3
                }
            }

            c2=new C2(op1,op2,this.result*op3);
            methods=c2.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push('('+methods[j]+")"+"/"+op3);// [op1,op2]/op3
                }
            }

            c2=new C2(op1,op2,this.result-op3);
            methods=c2.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push('('+methods[j]+")"+"+"+op3);// [op1,op2]+op3
                }
            }

            c2=new C2(op1,op2,op3-this.result);
            methods=c2.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push(op3+"-"+'('+methods[j]+")");// op3-[op1,op2]
                }
            }

            c2=new C2(op1,op2,this.result/op3);
            methods=c2.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push('('+methods[j]+")"+"*"+op3);// [op1,op2]*op3
                }
            }

            c2=new C2(op1,op2,op3/this.result);
            methods=c2.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push(op3+"/"+'('+methods[j]+")");// op3/[op1,op2]
                }
            }
        }

        return retArr;
    };

    return obj;
}

//======================================================
// C4类,用于判断三个数通过加减乘除运算能否得到某个结果
// C代表Caculate,4代表两个操作数
// op1:操作数1,op2:操作数2,op3:操作数3,op4:操作数4,result,结果
//======================================================
function C4(op1,op2,op3,op4,result){
    var obj=new Object();
    obj.op1=op1;
    obj.op2=op2;
    obj.op3=op3;
    obj.op4=op4;
    obj.result=result;

    obj.findComputationMethods=function(){
        var retArr=[];// 返回数组

        var permutationArr=[    [this.op1,this.op2,this.op3,this.op4],
                             [this.op1,this.op2,this.op4,this.op3],
                             [this.op1,this.op3,this.op2,this.op4],
                             [this.op1,this.op3,this.op4,this.op2],
                             [this.op1,this.op4,this.op2,this.op3],
                             [this.op1,this.op4,this.op3,this.op2],
                                [this.op2,this.op1,this.op3,this.op4],
                             [this.op2,this.op1,this.op4,this.op3],
                             [this.op2,this.op3,this.op1,this.op4],
                             [this.op2,this.op3,this.op4,this.op1],
                             [this.op2,this.op4,this.op1,this.op3],
                             [this.op2,this.op4,this.op3,this.op1],
                                [this.op3,this.op1,this.op2,this.op4],
                             [this.op3,this.op1,this.op4,this.op2],
                             [this.op3,this.op2,this.op1,this.op4],
                             [this.op3,this.op2,this.op4,this.op1],
                             [this.op3,this.op4,this.op1,this.op2],
                             [this.op3,this.op4,this.op2,this.op1],
                                [this.op4,this.op1,this.op2,this.op3],
                             [this.op4,this.op1,this.op3,this.op2],
                             [this.op4,this.op2,this.op1,this.op3],
                             [this.op4,this.op2,this.op3,this.op1],
                             [this.op4,this.op3,this.op1,this.op2],
                             [this.op4,this.op3,this.op2,this.op1],
                           ]; // 排列数组,四个操作数共有24种排列方式

        for(var i=0;i<permutationArr.length;i++){
            var arr=permutationArr[i];

            var op1=arr[0];
            var op2=arr[1];
            var op3=arr[2];
            var op4=arr[3];            

            var c3=new C3(op1,op2,op3,this.result+op4);
            var methods=c3.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push('('+methods[j]+")"+"-"+op4);// [op1,op2,op3]-op4
                }
            }

            var c3=new C3(op1,op2,op3,this.result*op4);
            var methods=c3.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push('('+methods[j]+")"+"/"+op4);// [op1,op2,op3]/op4
                }
            }

            var c3=new C3(op1,op2,op3,this.result-op4);
            var methods=c3.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push('('+methods[j]+")"+"+"+op4);// [op1,op2,op3]+op4
                }
            }

            var c3=new C3(op1,op2,op3,op4-this.result);
            var methods=c3.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push(op4+"-"+'('+methods[j]+")");// op4-[op1,op2,op3]
                }
            }

            var c3=new C3(op1,op2,op3,this.result/op4);
            var methods=c3.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push('('+methods[j]+")"+"*"+op4);// [op1,op2,op3]*op4
                }
            }

            var c3=new C3(op1,op2,op3,op4/this.result);
            var methods=c3.findComputationMethods();
            if(methods.length>0){
                for(var j=0;j<methods.length;j++){
                    retArr.push(op4+"/"+'('+methods[j]+")");// op4/[op1,op2,op3]
                }
            }

            if(op1*op2-op3*op4==result){
                retArr.push(op1+"*"+op2+"-"+op3+"*"+op4);// op1*op2-op3*op4,这是c3里不曾有的
            }

            if(op1*op2+op3*op4==result){
                retArr.push(op1+"*"+op2+"+"+op3+"*"+op4);// op1*op2+op3*op4,这是c3里不曾有的
            }

            if(op1/op2-op3/op4==result){
                retArr.push(op1+"/"+op2+"-"+op3+"/"+op4);// op1/op2-op3/op4,这是c3里不曾有的
            }

            if(op1/op2+op3/op4==result){
                retArr.push(op1+"/"+op2+"+"+op3+"/"+op4);// op1/op2+op3/op4,这是c3里不曾有的
            }

            if(op1*op2-op3/op4==result){
                retArr.push(op1+"*"+op2+"-"+op3+"/"+op4);// op1*op2-op3/op4,这是c3里不曾有的
            }

            if(op1*op2+op3/op4==result){
                retArr.push(op1+"*"+op2+"+"+op3+"/"+op4);// op1*op2+op3/op4,这是c3里不曾有的
            }
        }

        return retArr;
    }

    return obj;
}

//======================================================
// 用来得到仅包含不重复元素的数组
//======================================================
function getDistinctArray(arr){
    var returnArr=new Array();

    var sortedArr=arr.sort();
    for(var i=0;i<sortedArr.length;i++){
        if(returnArr[returnArr.length-1]!=sortedArr[i]){
            returnArr.push(sortedArr[i]);
        }
    }

    return returnArr;
}

//======================================================
// 程序入口
//======================================================
function main(){
    /*var c4=new C4(6,7,10,10,24);
    var arr=getDistinctArray(c4.findComputationMethods());

    for(var i=0;i<arr.length;i++){
        console.log(arr[i]+"=24");
    }    */

    process.stdin.resume();
    process.stdout.write("\033[33m 请输入四个数字,用逗号分隔: \033[39m");// 草黄色
    process.stdin.setEncoding('utf8');

    process.stdin.on('data',function(text){
        var input=text.trim();
        process.stdin.end();// 退出输入状态  

        var arrTemp=input.split(",");
        var op1=parseInt(arrTemp[0],10);
        var op2=parseInt(arrTemp[1],10);
        var op3=parseInt(arrTemp[2],10);
        var op4=parseInt(arrTemp[3],10);

        var c4=new C4(op1,op2,op3,op4,24);
        var arr=getDistinctArray(c4.findComputationMethods());

        if(arr.length>0){
            for(var i=0;i<arr.length;i++){
                console.log(arr[i]+"=24");
            }
        }else{
            console.log(input+"这四个数无法计算得到24");
        }
    });
}

// 开始
main();

控制台输出示例如下:

C:\Users\horn1\Desktop\node.js\54-算24c41.01>node c24.js
 请输入四个数字,用逗号分隔: 4,8,13,2
((13*8)/4)-2=24
((13/4)*8)-2=24
((8*13)/4)-2=24
((8/4)*13)-2=24
(13/(4/8))-2=24
(8/(4/13))-2=24
13*2-8/4=24
2*13-8/4=24

C:\Users\horn1\Desktop\node.js\54-算24c41.01>node c24.js
 请输入四个数字,用逗号分隔: 2,7,5,11
((11*2)+7)-5=24
((11*2)-5)+7=24
((11*5)-7)/2=24
((2*11)+7)-5=24
((2*11)-5)+7=24
((5*11)-7)/2=24
((7-5)*11)+2=24
2-((5-7)*11)=24
7-(5-(11*2))=24
7-(5-(2*11))=24

C:\Users\horn1\Desktop\node.js\54-算24c41.01>node c24.js
 请输入四个数字,用逗号分隔: 13,11,1,3
13,11,1,3这四个数无法计算得到24

C:\Users\horn1\Desktop\node.js\54-算24c41.01>node c24.js
 请输入四个数字,用逗号分隔: 8,11,1,3
((11*3)-1)-8=24
((11*3)-8)-1=24
((3*11)-1)-8=24
((3*11)-8)-1=24

【Nodejs】“快算24”扑克牌游戏算法 1.01的更多相关文章

  1. 【Nodejs】“快算24”扑克牌游戏算法

    算24是一款扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过四则运算得到结果24,四张牌必须仅用一次.这是一种挺好的锻炼孩子算数能力的扑克牌游戏. 各地玩法还有点差别,有的只算1-10,其它抽出来:有 ...

  2. 【Nodejs】“快算24”扑克牌游戏算法 1.02

    快算24是一种挺好的锻炼孩子算数能力的扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过有限四则运算得到结果24,四张牌必须仅用一次.各地玩法还有点差别,有的只算1-10,其它抽出来:有的地方把整幅牌都 ...

  3. php实现 24点游戏算法

    php实现 24点游戏算法 一.总结 一句话总结:把多元运算转化为两元运算,先从四个数中取出两个数进行运算,然后把运算结果和第三个数进行运算,再把结果与第四个数进行运算.在求表达式的过程中,最难处理的 ...

  4. POJ 3983:快算24

    快算24 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4791   Accepted: 2930 Description ...

  5. 快算24点,POJ(3983)

    题目链接:http://poj.org/problem?id=3983 中文题,就不解释题意了. 类似之前的一篇博客,这里也不上解释了,直接上代码吧. #include <iostream> ...

  6. POJ3983 快算24

    很正常的题目,迷一样的答案. 测试数据只有一组,对没错只有一组. #include<cstdio> int main() { printf("5*(5-(1/5))\n" ...

  7. python实现算24的算法

    1.介绍 给定4个整数,数字范围在1-13之间,任意使用 + - * / ( ) ,构造出一个表达式,使得最终结果为24,这就是常见的算24的游戏.本文介绍用Python语言实现的两种方式.2.实现思 ...

  8. 用python代替人脑运算24点游戏

    前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:老方玩编程 PS:如有需要Python学习资料的小伙伴可以加点击下方链 ...

  9. python实例:解决经典扑克牌游戏 -- 四张牌凑24点 (二)

    Hey! 如果你还没有看这篇的上文的话,可以去稍稍瞅一眼,会帮助加速理解这一篇里面涉及到的递归结构哦!(上一篇点这里:<python实例:解决经典扑克牌游戏 -- 四张牌凑24点 (一)> ...

随机推荐

  1. [HNOI2011]数学作业 --- 矩阵优化

    [HNOI2011]数学作业 题目描述: 小 C 数学成绩优异,于是老师给小 C 留了一道非常难的数学作业题: 给定正整数 N 和 M ,要求计算\(Concatenate(1..N)\; Mod\; ...

  2. hdu 4858 水题

    题意:我们建造了一个大项目!这个项目有n个节点,用很多边连接起来,并且这个项目是连通的!两个节点间可能有多条边,不过一条边的两端必然是不同的节点.每个节点都有一个能量值.现在我们要编写一个项目管理软件 ...

  3. HDU 5714 拍照 前缀和

    拍照 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5714 Description 小明在旅游的路上看到了一条美丽的河,河上有许多船只,有的船只向左 ...

  4. AES advanced encryption standard

    // advanced encryption standard // author: karl malbrain, malbrain@yahoo.com typedef unsigned char u ...

  5. linux下安装MYSQL详细配置(转)

      #tar zxvf mysql-5.0.18.tar.gz#cd  mysql-5.0.18 #./configure --prefix=/usr/local/mysql --with-chars ...

  6. 中国LINUX内核开发大会 ppt演讲资料 与 会议视频

    http://www.ckernel.org/ http://pan.baidu.com/share/home?uk=2086779999&view=share#category/type=0

  7. C语言内存分析

    C语言内存分析 一.进制 概念:进制是一种计数方式,是数值的表现形式 4种主要的进制: ①. 十进制:0~9 ②. 二进制:0和1 ③. 八进制:0~7 ④. 十六进制:0~9+a b c d e f ...

  8. 转 ios给view设置圆角

    // 圆角 userhead.layer.masksToBounds = YES; userhead.layer.cornerRadius = 6.0; userhead.layer.borderWi ...

  9. shader内置变量

    内置变量都在UnityShaderVariables.cginc文件中声明 变换矩阵 All these matrices arefloat4x4 type. Name Value UNITY_MAT ...

  10. Eclipse调试:改变颜色, 背景与字体大小 和xml字体调整

    http://blog.csdn.net/qq272803220/article/details/7292699 eclipse操作界面默认颜色为白色.对于我们长期使用电脑编程的人来说,白色很刺激我们 ...