试试手气(Python)

题目描述

试试手气

试试手气(Python)_第1张图片
我们知道一个骰子有 6 个面,分别刻了 1 到 6 个点。下面给你 6 个骰子的初始状态,即它们朝上一面的点数,让你一把抓起摇出另一套结果。假设你摇骰子的手段特别精妙,每次摇出的结果都满足以下两个条件:

  • 1、每个骰子摇出的点数都跟它之前任何一次出现的点数不同;
  • 2、在满足条件 1 的前提下,每次都能让每个骰子得到可能得到的最大点数。
    那么你应该可以预知自己第 n n n ( 1 ≤ n ≤ 5 ) (1≤n≤5) (1n5) 摇出的结果。
输入格式:

输入第一行给出 6 个骰子的初始点数,即 [ 1 , 6 ] [1,6] [1,6] 之间的整数,数字间以空格分隔;第二行给出摇的次数 n ( 1 ≤ n ≤ 5 ) n(1≤n≤5) n(1n5)

输出格式:

在一行中顺序列出第 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. 每个骰子摇出的点数都跟它之前任何一次出现的点数不同;
  2. 在满足条件 1 的前提下,每次都能让每个骰子得到可能得到的最大点数。

根据以上条件,我们可以得出以下结论:

  1. 每个骰子第一次摇出的结果是固定的,即初始状态;
  2. 对于每个骰子的第二次摇出结果,可以分两种情况讨论:
    • 如果初始状态下的点数加上 n 大于 6,则第二次摇出的结果是 6-n;
    • 如果初始状态下的点数加上 n 小于等于 6,则第二次摇出的结果是 7-n;
  3. 以此类推,对于第三次、第四次、第五次摇出的结果,可以按照相同的规则计算。

因此,我们可以使用一个循环遍历骰子的六个面,根据上述规则计算出每次摇出的结果,并将结果存储在一个列表中。

最后,将列表中的结果以空格分隔输出即可。

根据上述思路,我们可以编写代码实现这个过程。


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))

你可能感兴趣的:(Python,python)