Python生成扫雷地图(并非游戏实现)

部署运行你感兴趣的模型镜像

需求说明

输入:行数m、列数n、地雷数k
输出:随机扫雷地图

第一步,生成地图和随机地雷
第二步,没有地雷的格子填充数字,该数字表示周边地雷总数

思路

代码实现

下面2种实现,分别是不用numpy和用numpy,思路是一样的

from random import shuffle

# 行数、列数、地雷数
m, n, k = 5, 10, 15

# 地雷符号,此处用9表示
landmine = 9

# 初始化序列,总长为m*n,k前是雷,k后是0
ls = [landmine for _ in range(k)] + [0 for _ in range(m * n - k)]

# 打乱序列顺序,达到随机的效果
shuffle(ls)

# m*n的序列=>m行n列的矩阵
matrix = [[ls[i + j * n] for i in range(n)] for j in range(m)]

# 对没有雷的格子填充数字,该数字表示周围地雷总数,注意边缘格子,不要越界
for i in range(m):
    for j in range(n):
        if matrix[i][j] == 0:
            matrix[i][j] = sum(
                1 for a in range(max(i - 1, 0), min(i + 2, m))
                for b in range(max(j - 1, 0), min(j + 2, n))
                if matrix[a][b] == landmine)

# 最终结果展示
[print(v) for v in matrix]
import numpy as np

# 行数、列数、地雷数
m, n, k = 5, 10, 15

# 地雷符号,此处用9表示
landmine = 9

# 初始化总长为m*n的序列,TopK是雷,k后是0
ls = [landmine for _ in range(k)] + [0 for _ in range(m * n - k)]
print(ls)

# 打乱序列顺序,达到随机的效果
np.random.shuffle(ls)
print(ls)

# m*n的序列=>m行n列的矩阵
matrix = np.reshape(ls, (m, n))
print(matrix)

# 对没有雷的格子填充数字,该数字表示周围地雷总数,注意边缘格子,不要越界
for i in range(m):
    for j in range(n):
        if matrix[i][j] == 0:
            matrix[i][j] = sum(
                1 for a in range(max(i - 1, 0), min(i + 2, m))
                for b in range(max(j - 1, 0), min(j + 2, n))
                if matrix[a][b] == landmine)

# 最终结果展示
print(matrix)

您可能感兴趣的与本文相关的镜像

Python3.10

Python3.10

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小基基o_O

您的鼓励是我创作的巨大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值