首页 > 编程语言 > 详细

python 24点

时间:2020-10-17 22:31:44      阅读:32      评论:0      收藏:0      [点我收藏+]
 1 #事先声明,这里的 + - * / 按照的是 出现顺序直接计算,并没有考虑优先级
 2 def operator(a, op, b):
 3     if op == +:
 4         return a+b
 5     elif op == -:
 6         return a-b
 7     elif op == *:
 8         return a*b
 9     else:
10         return a/b
11 
12 list_operator = [+, -, *, /]
13 card1, card2, card3, card4 = map(int, input(请输入四个扑克牌的大小: ).split( ))
14 list_card = [card1, card2, card3, card4]
15 list_total = []#所有已经满足24点的式子
16 list_check = []#需要检查是否存在的式子
17 flag = 0#用来表示是否出现重复式子
18 
19 for i in range(len(list_card)):
20     for j in range(len(list_card)):
21         if i != j:
22             for t1 in range(len(list_operator)):
23                 sum1 = operator(list_card[i], list_operator[t1], list_card[j])
24                 for k in range(len(list_card)):
25                     if k != j and k != i:
26                         for t2 in range(len(list_operator)):
27                             sum2 = operator(sum1, list_operator[t2], list_card[k])
28                             for g in range(len(list_card)):
29                                 if g != k and g != i and g != j:
30                                     for t3 in range(len(list_operator)):
31                                         flag = 0#只在最后一个地方 清零即可,因为这里是必须经过的
32                                         list_check = []#把check列表也清空
33                                         sum3 = operator(sum2, list_operator[t3], list_card[g])
34                                         if sum3 == 24:
35                                             list_check.append(list_card[i])
36                                             list_check.append(list_operator[t1])
37                                             list_check.append(list_card[j])
38                                             list_check.append(list_operator[t2])
39                                             list_check.append(list_card[k])
40                                             list_check.append(list_operator[t3])
41                                             list_check.append(list_card[g])
42                                             #用来检查是否有重复的式子
43                                             for v in range(len(list_total)):
44                                                 if list_check == list_total[v]:
45                                                     flag = 1
46                                                     break
47                                             if flag == 1:#如果存在,那么就直接跳过这次输出
48                                                 break
49                                             print(list_card[i], list_operator[t1], list_card[j], list_operator[t2],
50                                                   list_card[k], list_operator[t3], list_card[g])
51                                             list_total.append(list_check)#在total列表的最后加上新式子
52 
53 
54 
55  

 

python 24点

原文:https://www.cnblogs.com/letianpaiai/p/13832385.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!