算法提高 扫雷

时间限制:1.0s 内存限制:256.0MB

问题描述

  扫雷游戏你一定玩过吧!现在给你若干个n×m的地雷阵,请你计算出每个矩阵中每个单元格相邻单元格内地雷的个数,每个单元格最多有8个相邻的单元格。 0<n,m<=100

输入格式

  输入包含若干个矩阵,对于每个矩阵,第一行包含两个整数n和m,分别表示这个矩阵的行数和列数。接下来n行每行包含m个字符。安全区域用‘.’表示,有地雷区域用’‘表示。当n=m=0时输入结束。

输出格式

  对于第i个矩阵,首先在单独的一行里打印序号:“Field #i:”,接下来的n行中,读入的’.'应被该位置周围的地雷数所代替。输出的每两个矩阵必须用一个空行隔开。

样例输入

4 4





.




3 5

**…



.


0 0

样例输出

Field #1:

100

2210

1
10

1110

Field #2:

**100

33200

1*100

(注意两个矩阵之间应该有一个空行,由于oj的格式化这里不能显示出来)

数据规模和约定

  0<n,m<=100

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner; public class 扫雷 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
List<StringBuffer> sb=new ArrayList<StringBuffer>();
int count=1;
while(true){
int a=sc.nextInt();
int b=sc.nextInt();
if(a==b&&a==0)
break;
int[][] arr=new int[a][b];
sc.nextLine();
for(int i=0;i<a;i++){
String str=sc.nextLine();
for(int j=0;j<b;j++){
if(str.charAt(j)=='*')
arr[i][j]=9;
else if(str.charAt(j)=='.')
arr[i][j]=0;
}
}
for(int i=0;i<a;i++){
for(int j=0;j<b;j++){
if(arr[i][j]==9){
if(i-1>=0&&j-1>=0&&arr[i-1][j-1]!=9)
arr[i-1][j-1]++;
if(i-1>=0&&arr[i-1][j]!=9)
arr[i-1][j]++;
if(i-1>=0&&j+1<b&&arr[i-1][j+1]!=9)
arr[i-1][j+1]++;
if(j-1>=0&&arr[i][j-1]!=9)
arr[i][j-1]++;
if(j+1<b&&arr[i][j+1]!=9)
arr[i][j+1]++;
if(i+1<a&&j-1>=0&&arr[i+1][j-1]!=9)
arr[i+1][j-1]++;
if(i+1<a&&arr[i+1][j]!=9)
arr[i+1][j]++;
if(i+1<a&&j+1<b&&arr[i+1][j+1]!=9)
arr[i+1][j+1]++;
}
}
}
String s="Field #"+count+":";
sb.add(new StringBuffer(s));
for(int i=0;i<a;i++){
StringBuffer bu=new StringBuffer();
for(int j=0;j<b;j++){
if(arr[i][j]==9)
bu.append('*');
else
bu.append(arr[i][j]);
}
sb.add(bu);
}
StringBuffer bb=new StringBuffer('\n');
sb.add(bb);
count++;
}
for(int i=0;i<sb.size();i++)
System.out.println(sb.get(i));
} }

最新文章

  1. centos7+mono4+jexus5.6.2安装过程中的遇到的问题
  2. SqlServer按中文数字排序
  3. SQL Server编程(06)触发器
  4. JS如何判断包括IE11在内的IE浏览器 &lt;转载&gt;
  5. Linux 下三种方式设置环境变量
  6. cVim—Chrome上更强大的vim插件
  7. SharePoint 2013 Nintex Workflow 工作流帮助(一)
  8. PB串口编程资料(转)
  9. H264码流打包分析(精华)
  10. dojo(四):ajax请求
  11. 编译 Spring-framework的经验分享
  12. 【译】ASP.NET MVC 5 教程 - 7:Edit方法和Edit视图详解
  13. slf4j(simple logging facade for java)
  14. 《JavaScript闯关记》视频版硬广
  15. a,b值进行交换的方法
  16. CF1056E Check Transcription 字符串哈希
  17. 初试Django的缓存系统
  18. 【转】SQLyog SSH 密钥登陆认证提示: No supported authentication methods available 解决方法
  19. BZOJ 1143: [CTSC2008]祭祀river(二分图最大点独立集)
  20. Java的四个基本特性和对多态的理解

热门文章

  1. Codeforces Round #635C Linova and Kingdom 思维
  2. 数据库当中删除数据后主键id不连续的问题
  3. java.sql.SQLException: The server time zone value &#39;&#214;&#208;&#185;&#250;&#177;&#234;&#215;&#188;&#202;&#177;&#188;&#228;&#39; is unrecognized的报错问题
  4. git切换账号
  5. AT命令集详解
  6. 关于vue打包后,访问不到页面和访问不到图片。
  7. .NET 合并程序集(将 dll 合并到 exe 中)
  8. RenderBox使用说明书&amp;原理浅析
  9. 点击劫持ClickJacking
  10. Word与Excel中,如何输入✔标志