java 板


LINE

大家好 最近做到一题对我来说满困扰的题目 虽然我做出来的答案 题库跑case的结果是对的 但是还是觉得应该有更好的解法 所以上来问问看 (因为我没修过演算法 所以觉得自己很土法炼钢= =) 题目: 简单来说 题目会给Input 第一行先表示这个踩地雷是nxn的阵列 接下来会给n行其中阵列的排序 有地雷就会写1 没有就是0 那output就是要印出每一格的周边地雷数目 本身是地雷给X 不然就给数字 都没有给- ex. 1. input: 4 4 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 1 output: 111- 1X1- 1121 --1X 2. input: 4 6 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 1 0 0 0 0 0 output: ----1X 111-11 2X1--- X21--- 我的写法: import java.util.Scanner; public class mineSweeper { public static void main(String[] args) { Scanner sc = new Scanner(System.in); while (sc.hasNext()) { int numX = sc.nextInt(); int numY = sc.nextInt(); sc.nextLine(); String[][] inputArray = new String[numX][]; String[][] outputArray = new String[numX][numY]; for(int i=0;i<numX;i++){ inputArray[i] = sc.nextLine().split(" "); } for(int j=0;j<numX;j++){ for(int k=0;k<numY;k++){ if(inputArray[j][k].equals("1")){ outputArray[j][k]="X"; }else{ int mineAround=0; if(j>0 & k>0){ if(inputArray[j-1][k-1].equals("1")){ mineAround++; } } if(j>0 ){ if(inputArray[j-1][k].equals("1")){ mineAround++; } } if(j>0 & k+1<numY){ if(inputArray[j-1][k+1].equals("1")){ mineAround++; } } if(k+1<numY ){ if(inputArray[j][k+1].equals("1")){ mineAround++; } } if(j+1<numX & k+1<numY ){ if(inputArray[j+1][k+1].equals("1")){ mineAround++; } } if(j+1<numX ){ if(inputArray[j+1][k].equals("1")){ mineAround++; } } if(j+1<numX & k>0 ){ if(inputArray[j+1][k-1].equals("1")){ mineAround++; } } if(k>0 ){ if(inputArray[j][k-1].equals("1")){ mineAround++; } } if(mineAround==0){ outputArray[j][k]="-"; }else{ outputArray[j][k]=String.valueOf(mineAround); } } } } for(int i=0;i<numX;i++){ for(int j=0;j<numY;j++){ System.out.print(outputArray[i][j]); } System.out.println(); } } sc.close(); } } ----------------------------------(分隔线)-------------------------------- 程式码是直接从IDE贴上在用手排的 有点乱不好意思 如果有其他不符合板规的地方 麻烦再跟我说一下 我会改 谢谢 --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 60.248.4.126
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/java/M.1493439046.A.C28.html
1F:推 lazarus1121: 帮output打x的时候可以顺便帮他四周8格+1,应该能省 04/29 13:06
2F:→ lazarus1121: 不少时间 04/29 13:06
3F:→ lazarus1121: 整张input扫完output就直接出来了 04/29 13:09
但是这还是要考虑到array index outofbound的问题 而且因为输出的是string 所以'-'也要另外处理的感觉
4F:→ gameking: 你要更简单其实用一维阵列就可以写了 但是程式码变简单 04/29 13:09
5F:→ gameking: 就表示你写的时候想法会复杂很多 普法炼钢程式反而易懂 04/29 13:09
恩..我了解程式码这样好看许多 我只是在想有没有厉害的演算法能够更聪明的做好 ※ 编辑: bb7889 (140.119.121.6), 04/29/2017 13:31:32
6F:→ gameking: 照一楼讲的方法可行阿 你OUTPUT弄成INT阵列就好了 04/29 14:16
7F:→ gameking: 反正地雷最多数字到8 你有地雷的地方就设成9 没有就0 04/29 14:17
8F:→ gameking: 整个INPUT扫完 OUTPUT的INT阵列完成 04/29 14:17
9F:→ gameking: 再用一个回圈判别数字来输出就好了 没有一定要STRING存 04/29 14:18
10F:→ gameking: 每个单位检查旁边八格有无地雷 VS 有地雷的旁边八格+1 04/29 14:22
11F:→ gameking: 明显後者快很多啊 04/29 14:23







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:WOW站内搜寻

TOP