`
betakoli
  • 浏览: 169163 次
社区版块
存档分类
最新评论

华为上机题之Word Maze(单词迷宫)

 
阅读更多

Word Maze 是一个网络小游戏,你需要找到以字母标注的食物,但要求以给定单词字母的顺序吃掉。如上图,假设给定单词if,你必须先吃掉i然后才能吃掉f。


    但现在你的任务可没有这么简单,你现在处于一个迷宫Maze(n×m的矩阵)当中,里面到处都是以字母标注的食物,但你只能吃掉能连成给定单词W的食物。


如下图,指定W为“SOLO”,则在地图中红色标注了单词“SOLO”。 

 

注意区分英文字母大小写,你只能上下左右行走。

输入:

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[i][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[i].length; j++) {
				if (arrs[i][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[i][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;
			}
		}
	}
}

 

 

分享到:
评论

相关推荐

    华为2013.9.22上机试题

    通常,Word Maze问题可能会涉及到构造或解决基于字符的迷宫游戏,可能需要对字符或字符串进行位操作以生成或解码迷宫路径。 这些是根据给定的代码片段所涵盖的主要编程知识点。理解和掌握这些概念对于解决类似的...

    华为OD机试C卷- 迷宫问题(Java & JS & Python).md-私信看全套OD代码及解析

    本题目是华为OD机试中的经典算法题之一,主要考察考生对于图遍历算法的理解与实现能力,特别是对于广度优先搜索(BFS)的应用。 #### 题目描述 给定一个二维数组`N * M`,数组中的值为0或1,0代表可以通过的路径,...

    华为2014校园招聘长沙机试

    4. 数组和矩阵操作:第三题“Word Maze”可能要求解决迷宫问题,涉及到二维数组(矩阵)的处理,包括查找路径、判断可行路径等。数组和矩阵是数据结构的基础,对于解决许多实际问题,如图像处理、游戏设计等,都有...

    matlab-迷宫路径

    matlab代码,有标注,题目源自牛客网华为机试。 定义一个二维数组N*M(其中2;2),如5 × 5数组下所示: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, }; 它...

    基于OpenCV的人脸识别小程序.zip

    【项目资源】: 包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。 包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    精选毕设项目-宅男社区.zip

    精选毕设项目-宅男社区

    精选毕设项目-扫描条形码.zip

    精选毕设项目-扫描条形码

    配网两阶段鲁棒优化调度模型 关键词:两阶段鲁棒优化,CCG算法,储能 仿真算例采用33节点,采用matlab+yalmip+cplex编写,两阶段模型采用CCG算法求解 模型中一阶段变量主要包括01

    配网两阶段鲁棒优化调度模型 关键词:两阶段鲁棒优化,CCG算法,储能 仿真算例采用33节点,采用matlab+yalmip+cplex编写,两阶段模型采用CCG算法求解。 模型中一阶段变量主要包括01变量和无功优化变量,核心变量主要存在于二阶段,因此在叠加二阶段变量优化过程中更容易得到最优解,所以有限次迭代即得到收敛的结果。 模型以网损为目标,包括功率平衡、网络潮流、电压电流、蓄电池出力以及无功设备出力等约束。 复现《两阶段鲁棒优化的主动配电网动态无功优化》-熊壮壮,具体内容可自行下载了解。

    comsol光栅仿真 计算复合波导光栅准BIC增强古斯汉森位移

    comsol光栅仿真 计算复合波导光栅准BIC增强古斯汉森位移

    精选毕设项目-车源宝寻车广场.zip

    精选毕设项目-车源宝寻车广场

    数字农业产业项目整体解决方案.pdf

    数字农业产业项目整体解决方案

    精选毕设项目-幸运大抽奖.zip

    精选毕设项目-幸运大抽奖

    SRS构型七自由度冗余机械臂运动学建模全套matlab代码 代码主要功能: 1. 基于臂角参数化方法求解机械臂在给定末端位姿和臂角下的关节角度; 2. 求解机械臂在给定末端位姿下的有效臂角范围

    SRS构型七自由度冗余机械臂运动学建模全套matlab代码 代码主要功能: [1]. 基于臂角参数化方法求解机械臂在给定末端位姿和臂角下的关节角度; [2]. 求解机械臂在给定末端位姿下的有效臂角范围,有效即在该区间内机械臂关节角度不会超出关节限位; [3]. 以避关节限位为目标在有效臂角区间内进行最优臂角的选取,进而获取机械臂在给定末端位姿下的最优关节角度。 购前须知: 1. 代码均为个人手写,主要包含运动学建模全套代码; 2. 代码已经包含必要的注释; 包含原理推导文档,不包含绘图脚本以及urdf;

    精选毕设项目-微信小程序天气源码.zip

    精选毕设项目-微信小程序天气源码

    bmjebm-29-6.pdf

    bmjebm-29-6.pdf

    chromedriver-linux64_123.0.6273.0.zip

    chromedriver-linux64_123.0.6273.0

    精选毕设项目-腾讯云小程序一站式解决方案.zip

    精选毕设项目-腾讯云小程序一站式解决方案

    精选毕设项目-仿饿了么.zip

    精选毕设项目-仿饿了么

    学生宿舍管理系统的设计与开发-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip

    Spring Boot是Spring框架的一个模块,它简化了基于Spring应用程序的创建和部署过程。Spring Boot提供了快速启动Spring应用程序的能力,通过自动配置、微服务支持和独立运行的特性,使得开发者能够专注于业务逻辑,而不是配置细节。Spring Boot的核心思想是约定优于配置,它通过自动配置机制,根据项目中添加的依赖自动配置Spring应用。这大大减少了配置文件的编写,提高了开发效率。Spring Boot还支持嵌入式服务器,如Tomcat、Jetty和Undertow,使得开发者无需部署WAR文件到外部服务器即可运行Spring应用。 Java是一种广泛使用的高级编程语言,由Sun Microsystems公司(现为Oracle公司的一部分)在1995年首次发布。Java以其“编写一次,到处运行”(WORA)的特性而闻名,这一特性得益于Java虚拟机(JVM)的使用,它允许Java程序在任何安装了相应JVM的平台上运行,而无需重新编译。Java语言设计之初就是为了跨平台,同时具备面向对象、并发、安全和健壮性等特点。 Java语言广泛应用于企业级应用、移动应用、桌面应用、游戏开发、云计算和物联网等领域。它的语法结构清晰,易于学习和使用,同时提供了丰富的API库,支持多种编程范式,包括面向对象、命令式、函数式和并发编程。Java的强类型系统和自动内存管理减少了程序错误和内存泄漏的风险。随着Java的不断更新和发展,它已经成为一个成熟的生态系统,拥有庞大的开发者社区和持续的技术创新。Java 8引入了Lambda表达式,进一步简化了并发编程和函数式编程的实现。Java 9及以后的版本继续在模块化、性能和安全性方面进行改进,确保Java语言能够适应不断变化的技术需求和市场趋势。 MySQL是一个关系型数据库管理系统(RDBMS),它基于结构化查询语言(SQL)来管理和存储数据。MySQL由瑞典MySQL AB公司开发,并于2008年被Sun Microsystems收购,随后在2010年,Oracle公司收购了Sun Microsystems,从而获得了MySQL的所有权。MySQL以其高性能、可靠性和易用性而闻名,它提供了多种特性来满足不同规模应用程序的需求。作为一个开源解决方案,MySQL拥有一个活跃的社区,不断为其发展和改进做出贡献。它的多线程功能允许同时处理多个查询,而其优化器则可以高效地执行复杂的查询操作。 随着互联网和Web应用的快速发展,MySQL已成为许多开发者和公司的首选数据库之一。它的可扩展性和灵活性使其能够处理从小规模应用到大规模企业级应用的各种需求。通过各种存储引擎,MySQL能够适应不同的数据存储和检索需求,从而为用户提供了高度的定制性和性能优化的可能性。

    精选毕设项目-体育新闻赛事数据.zip

    精选毕设项目-体育新闻赛事数据

Global site tag (gtag.js) - Google Analytics