• L1-072 刮刮彩票(Python3)


    “刮刮彩票”是一款网络游戏里面的一个小游戏。如图所示:

    每次游戏玩家会拿到一张彩票,上面会有 9 个数字,分别为数字 1 到数字 9,数字各不重复,并以 3×3 的“九宫格”形式排布在彩票上。

    在游戏开始时能看见一个位置上的数字,其他位置上的数字均不可见。你可以选择三个位置的数字刮开,这样玩家就能看见四个位置上的数字了。最后玩家再从 3 横、3 竖、2 斜共 8 个方向中挑选一个方向,方向上三个数字的和可根据下列表格进行兑奖,获得对应数额的金币。

    数字合计获得金币数字合计获得金币
    610,0001672
    73617180
    872018119
    93601936
    108020306
    11252211,080
    1210822144
    1372231,800
    1454243,600
    15180

    现在请你写出一个模拟程序,模拟玩家的游戏过程。

    输入格式:

    输入第一部分给出一张合法的彩票,即用 3 行 3 列给出 0 至 9 的数字。0 表示的是这个位置上的数字初始时就能看见了,而不是彩票上的数字为 0。

    第二部给出玩家刮开的三个位置,分为三行,每行按格式 x y 给出玩家刮开的位置的行号和列号(题目中定义左上角的位置为第 1 行、第 1 列。)。数据保证玩家不会重复刮开已刮开的数字。

    最后一部分给出玩家选择的方向,即一个整数: 1 至 3 表示选择横向的第一行、第二行、第三行,4 至 6 表示纵向的第一列、第二列、第三列,7、8分别表示左上到右下的主对角线和右上到左下的副对角线。

    输出格式:

    对于每一个刮开的操作,在一行中输出玩家能看到的数字。最后对于选择的方向,在一行中输出玩家获得的金币数量。

    输入样例:

    1. 1 2 3
    2. 4 5 6
    3. 7 8 0
    4. 1 1
    5. 2 2
    6. 2 3
    7. 7

    输出样例:

    1. 1
    2. 5
    3. 6
    4. 180

    提交结果:

    代码:

    1. dict1 = {'6': 10000, '7': 36, '8': 720, '9': 360, '10': 80, '11': 252, '12': 108
    2. , '13': 72, '14': 54, '15': 180, '16': 72, '17': 180, '18': 119, '19': 36,
    3. '20': 306, '21': 1080, '22': 144, '23': 1800, '24': 3600}
    4. d = ['1', '2', '3', '4', '5', '6', '7', '8', '9']
    5. l = []
    6. for i in range(3):
    7. data = input().split()
    8. for j in data:
    9. if j in d:
    10. d.remove(j)
    11. l.append(data)
    12. for i in range(3):
    13. for j in range(3):
    14. if l[i][j] == '0':
    15. l[i][j] = d[0]
    16. a1 = input().split()
    17. a2 = input().split()
    18. a3 = input().split()
    19. a4 = int(input())
    20. print(l[int(a1[0]) - 1][int(a1[1]) - 1])
    21. print(l[int(a2[0]) - 1][int(a2[1]) - 1])
    22. print(l[int(a3[0]) - 1][int(a3[1]) - 1])
    23. sum1 = 0
    24. if a4 == 1:
    25. for i in l[0]:
    26. sum1 += int(i)
    27. elif a4 == 2:
    28. for i in l[1]:
    29. sum1 += int(i)
    30. elif a4 == 3:
    31. for i in l[2]:
    32. sum1 += int(i)
    33. elif a4 == 4:
    34. for i in range(3):
    35. sum1 += int(l[i][0])
    36. elif a4 == 5:
    37. for i in range(3):
    38. sum1 += int(l[i][1])
    39. elif a4 == 6:
    40. for i in range(3):
    41. sum1 += int(l[i][2])
    42. elif a4 == 7:
    43. sum1 = int(l[0][0]) + int(l[1][1]) + int(l[2][2])
    44. else:
    45. sum1 = int(l[0][2]) + int(l[1][1]) + int(l[2][0])
    46. print(dict1[str(sum1)])
  • 相关阅读:
    Linux调试器:gdb的使用
    7、设计模式之桥接模式(Bridge)
    kubernetes集群yaml文件与kubectl工具
    量化、蒸馏、分解、剪枝
    【sql】笔记大屏展示数据查询
    市面上有哪些好用的供应商管理系统?
    docker 安装nacos
    深入解析大数据分析:技术挑战、应用场景与未来趋势
    windows苹果商店上架ipa(基于appuploader)
    『现学现忘』Git基础 — 4、Git下载与安装
  • 原文地址:https://blog.csdn.net/weixin_55730361/article/details/126458648