Java实现 蓝桥杯VIP 算法提高 扫雷
2024-09-04 22:34:52
算法提高 扫雷
时间限制: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
110
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));
}
}
最新文章
- centos7+mono4+jexus5.6.2安装过程中的遇到的问题
- SqlServer按中文数字排序
- SQL Server编程(06)触发器
- JS如何判断包括IE11在内的IE浏览器 <;转载>;
- Linux 下三种方式设置环境变量
- cVim—Chrome上更强大的vim插件
- SharePoint 2013 Nintex Workflow 工作流帮助(一)
- PB串口编程资料(转)
- H264码流打包分析(精华)
- dojo(四):ajax请求
- 编译 Spring-framework的经验分享
- 【译】ASP.NET MVC 5 教程 - 7:Edit方法和Edit视图详解
- slf4j(simple logging facade for java)
- 《JavaScript闯关记》视频版硬广
- a,b值进行交换的方法
- CF1056E Check Transcription 字符串哈希
- 初试Django的缓存系统
- 【转】SQLyog SSH 密钥登陆认证提示: No supported authentication methods available 解决方法
- BZOJ 1143: [CTSC2008]祭祀river(二分图最大点独立集)
- Java的四个基本特性和对多态的理解
热门文章
- Codeforces Round #635C Linova and Kingdom 思维
- 数据库当中删除数据后主键id不连续的问题
- java.sql.SQLException: The server time zone value &#39;&#214;&#208;&#185;&#250;&#177;&#234;&#215;&#188;&#202;&#177;&#188;&#228;&#39; is unrecognized的报错问题
- git切换账号
- AT命令集详解
- 关于vue打包后,访问不到页面和访问不到图片。
- .NET 合并程序集(将 dll 合并到 exe 中)
- RenderBox使用说明书&;原理浅析
- 点击劫持ClickJacking
- Word与Excel中,如何输入✔标志