题解 | #24点游戏算法#

24点游戏算法

http://www.nowcoder.com/practice/fbc417f314f745b1978fc751a54ac8cb

时间有点长,但是效果还是不错的
import itertools
while True:
    try:
        nums_list = list(map(int,input().split(' ')))
        n = len(nums_list)
        order = ['+','-','*','/']
        for nums in itertools.permutations(nums_list):
            for i in order:
                for j in order:
                    for k in order:
                        result = eval('{0}{1}{2}'.format(nums[0],i,nums[1]))
                        result = eval('{0}{1}{2}'.format(result,j,nums[2]))
                        result = eval('{0}{1}{2}'.format(result,k,nums[3]))
                        if result == 24:
                            print("true")
                            raise ValueError
        else:
            print('false')
    except:
        break


全部评论

相关推荐

06-20 19:40
中原工学院 Java
网络存储:十几天不会让你拉人办卡就结束了吧?
点赞 评论 收藏
分享
看到这个内容真是闹麻了。。。。。。现在有了AI以后很多人面试都会作弊吗? 那对老老实实面试的人岂不是不公平....
程序员牛肉:公平那是对小孩子讲的童话故事,成年人的世界只有能不能接受失败的后果。 你要是能接受面试作弊被发现之后多家公司联合永久拉黑的后果,你就搞。
点赞 评论 收藏
分享
评论
3
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务