题目描述:
众所周知在扑克牌中,有一个老掉牙的游戏叫做24点,选取4张牌进行加减乘除,看是否能得出24这个答案。
现在小蓝同学发明了一个新游戏,他从扑克牌中依次抽出6张牌,注意不是一次抽出,进行计算,看是否能够组成 42 点,满足输出YES,反之输出 NO。
最先抽出来的牌作为第一个操作数,抽出牌做第二个操作数,运算结果在当作第一个操作数,继续进行操作。
除不尽的情况保留整数。
请设计一个程序对该问题进行解答。
样例:
输入:
K A Q 6 2 3
输出:
YES
最大运行时间:1s
最大运行内存: 128M
ans = [[] for i in range(10)]#十个储存结果的列表
a = ['0'] * 10#储存6张卡片
if __name__ == '__main__':
c = input().split()
for i in range(6):
if c[i] == 'A':
a[i] = 1
elif c[i] == 'J':
a[i] = 11
elif c[i] == 'Q':
a[i] = 12
elif c[i] == 'K':
a[i] = 13
else:
a[i]=int(c[i])
# a[i] = ord(c[i]) - ord('0')
ans[0].append(a[0])#把第一张卡片放进ans里
for i in range(1, 6):#后面五张卡片
for j in range(len(ans[i - 1])):
ans[i].append(ans[i - 1][j] + a[i])
ans[i].append(ans[i - 1][j] - a[i])
ans[i].append(ans[i - 1][j] * a[i])
ans[i].append(int(ans[i - 1][j] / a[i]))
flag = 0
for j in range(len(ans[5])):
if ans[5][j] == 42:
flag = 1
break
if flag == 1:
print("YES")
else:
print("NO")
print(ans)
print(ans[1])
print(len(ans[1]))
print(ans[1][0])
print(ans[1][1])
print(ans[2])
print(ans[2][0])
print(ans[2][1])