题目描述
试试手气
我们知道一个骰子有 6 个面,分别刻了 1 到 6 个点。下面给你 6 个骰子的初始状态,即它们朝上一面的点数,让你一把抓起摇出另一套结果。假设你摇骰子的手段特别精妙,每次摇出的结果都满足以下两个条件:
- 1、每个骰子摇出的点数都跟它之前任何一次出现的点数不同;
- 2、在满足条件 1 的前提下,每次都能让每个骰子得到可能得到的最大点数。
那么你应该可以预知自己第 n n n 次 ( 1 ≤ n ≤ 5 ) (1≤n≤5) (1≤n≤5) 摇出的结果。
输入格式:
输入第一行给出 6 个骰子的初始点数,即 [ 1 , 6 ] [1,6] [1,6] 之间的整数,数字间以空格分隔;第二行给出摇的次数 n ( 1 ≤ n ≤ 5 ) n(1≤n≤5) n(1≤n≤5)。
输出格式:
在一行中顺序列出第 n n n 次摇出的每个骰子的点数。数字间必须以 1 个空格分隔,行首位不得有多余空格。
输入样例:
3 6 5 4 1 4
3
输出样例:
4 3 3 3 4 3
样例解释:
这 3 次摇出的结果依次为:
6 5 6 6 6 6
5 4 4 5 5 5
4 3 3 3 4 3
解题思路
根据题目要求,每次摇骰子需要满足以下两个条件:
- 每个骰子摇出的点数都跟它之前任何一次出现的点数不同;
- 在满足条件 1 的前提下,每次都能让每个骰子得到可能得到的最大点数。
根据以上条件,我们可以得出以下结论:
- 每个骰子第一次摇出的结果是固定的,即初始状态;
- 对于每个骰子的第二次摇出结果,可以分两种情况讨论:
- 如果初始状态下的点数加上 n 大于 6,则第二次摇出的结果是 6-n;
- 如果初始状态下的点数加上 n 小于等于 6,则第二次摇出的结果是 7-n;
- 以此类推,对于第三次、第四次、第五次摇出的结果,可以按照相同的规则计算。
因此,我们可以使用一个循环遍历骰子的六个面,根据上述规则计算出每次摇出的结果,并将结果存储在一个列表中。
最后,将列表中的结果以空格分隔输出即可。
根据上述思路,我们可以编写代码实现这个过程。
Python代码实现
# 输入骰子的六个面的点数
dice = list(map(int, input().split()))
# 输入整数n
n = int(input())
# 初始化结果列表
result = []
# 遍历骰子的六个面
for i in range(6):
# 判断骰子当前面的点数加上n是否大于6
if dice[i] + n > 6:
result.append(str(6 - n))
else:
result.append(str(7 - n))
# 输出结果以空格分隔
print(' '.join(result))