首页 > 技术文章 > hihocoder刷题 扫雷游戏

qflyue 2018-01-14 15:02 原文

题目1 : 扫雷游戏

时间限制:10000ms
单点时限:1000ms
内存限制:256MB

描述

给定一个N × N的方格矩阵,其中每个格子或者是'*',表示该位置有一个地雷;或者是'.',表示该位置没有地雷:
*..*
..*.
....
****

现在小Hi希望你对于每一个'.',计算它周围8个方格中一共有多少颗地雷。并且用计算出的地雷数替换原来的'.':

*22*
12*2
2443
****

输入

第一行包含一个整数N,代表矩阵的大小。 (1 ≤ N ≤ 100)  

以下是一个N × N的矩阵,由字符'.'和'*'组成。

输出

一个N × N的矩阵,表示答案。

样例输入

4  
*..*  
..*.  
....
****

样例输出

*22*    
12*2  
2443
****

 

 

 

 

def main():
    number=input()
    li=[]
    for i in range(int(number)):
        li.append(list(input()))

    for i in range(int(number)):
        for j in range(int(number)):
            temp = 0
            if li[i][j]=='.':
                if i-1>=0 and j-1>=0:
                    if li[i-1][j-1]=='*':
                        temp+=1
                if i-1>=0:
                    if li[i-1][j]=='*':
                        temp+=1
                if i-1>=0 and j+1<=int(number)-1:
                    if li[i-1][j+1]=='*':
                        temp+=1
                if j-1>=0:
                    if li[i][j-1]=='*':
                        temp += 1
                if j+1<=int(number)-1:
                    if li[i][j+1]=='*':
                        temp += 1
                if i+1<=int(number)-1 and j-1>=0:
                    if li[i+1][j-1]=='*':
                        temp += 1
                if i+1<=int(number)-1:
                    if li[i+1][j]=='*':
                        temp+=1
                if i+1<=int(number)-1 and j+1<=int(number)-1:
                    if li[i+1][j+1]=='*':
                        temp+=1
                li[i][j]=temp
    for i in li:
        for j in i:
            print(j,end="")
        print()
if __name__ == '__main__':
    main()
py3code

 

推荐阅读