设为首页 收藏本站
查看: 1231|回复: 0

[经验分享] 华为上机题之Word Maze(单词迷宫)

[复制链接]

尚未签到

发表于 2016-6-7 07:22:08 | 显示全部楼层 |阅读模式
  Word Maze 是一个网络小游戏,你需要找到以字母标注的食物,但要求以给定单词字母的顺序吃掉。如上图,假设给定单词if,你必须先吃掉i然后才能吃掉f。
  
    但现在你的任务可没有这么简单,你现在处于一个迷宫Maze(n×m的矩阵)当中,里面到处都是以字母标注的食物,但你只能吃掉能连成给定单词W的食物。
  
如下图,指定W为“SOLO”,则在地图中红色标注了单词“SOLO”。 
DSC0000.jpg
  
  注意区分英文字母大小写,你只能上下左右行走。

  输入:
  5 5
  SOLO
  CPUCY
  EKLQH
  CRSOL
  EKLQO
  PGRBC
  输出:
  YES
  
  这道题目比较基础,遍历数组找到开头字母,再BFS或者DFS遍历就可以找到了。但是需要注意一点,就是字母不能重用,比如上面输入“SOLO”输出YES,但输入“SOLOL”则没返回结果,因为'L'重用。
  

import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;
public class Main {
static boolean result = false;
public static void main(String[] args) {
Scanner cin = new Scanner(System.in);
int n = 0, m = 0;
if (cin.hasNext()) {
n = cin.nextInt();
m = cin.nextInt();
}
String target = cin.next();
char arrs[][] = new char[n][m];
int i = 0;
while (cin.hasNext()) {
String temp = cin.next();
for (int j = 0; j < temp.length(); j++) {
arrs[j] = temp.charAt(j);
}
i++;
if (i == n)
break;
}
char first = target.charAt(0);
for (i = 0; i < arrs.length; i++) {
for (int j = 0; j < arrs.length; j++) {
if (arrs[j] == first) {
HashSet set = new HashSet();
find(arrs, n, m, i, j, target, set);
if (result)
break;
}
}
}
}
private static void find(char[][] arrs, int n, int m, int i, int j,
String target, HashSet hashSet) {
// TODO Auto-generated method stub
char first = target.charAt(0);
if (arrs[j] != first) {
return;
}
if (hashSet.contains(i + j)) {
return;
}
if (target.length() == 1) {
System.out.println("YES");
result = true;
return;
}
hashSet.add(i + j);
target = target.substring(1);
for (int len = 0; len < 4; len++) {
HashSet temp = new HashSet(hashSet);
switch (len) {
case 0:
if (i > 0)
find(arrs, n, m, i - 1, j, target, temp);
else
return;
break;
case 1:
if (i < n - 1)
find(arrs, n, m, i + 1, j, target, temp);
else
return;
break;
case 2:
if (j > 0)
find(arrs, n, m, i, j - 1, target, temp);
else
return;
break;
case 3:
if (j < m - 1)
find(arrs, n, m, i, j + 1, target, temp);
else
return;
break;
default:
break;
}
}
}
}

  
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-227145-1-1.html 上篇帖子: Mac下使用华为C8650进行安卓开发 下篇帖子: 华为练习 求二叉树的宽度和深度
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表