2024华为OD机试真题-找单词-(C++/Java/Python)-C卷D卷-200分

这篇博客主要介绍了华为在线开发者(OD)机试中关于查找单词的问题,涉及C++、Java和Python三种语言的解题方案。题目要求在二维字符数组中通过深度优先搜索(DFS)寻找字符串,找到则输出每个字符的行、列下标,未找到则返回"N"。博客内容包括题目描述、输入输出说明、用例、考点和解题思路,并提供了三种语言的代码实现。
摘要由CSDN通过智能技术生成

【华为OD机试】-(A卷+B卷+C卷+D卷)-2024真题合集目录

【华为OD机试】-(C卷+D卷)-2024最新真题目录

题目描述

给一个字符串和一个二维字符数组,如果该字符串存在于该数组中,则按字符串的字符顺序输出字符串每个字符所在单元格的位置下标字符串,如果找不到返回字符串“N”。

1.需要按照字符串的字符组成顺序搜索,且搜索到的位置必须是相邻单元格,其中“相邻单元格”是指那些水平相邻或垂直相邻的单元格。

2.同一个单元格内的字母不允许被重复使用。

3.假定在数组中最多只存在一个可能的匹配。

输入描述

第1行为一个数字N指示二维数组在后续输入所占的行数。

第2行到第N+1行输入为一个二维大写字符数组,每行字符用半角,分割。

第N+2行为待查找的字符串,由大写字符组成。

二维数组的大小为N*N,0<N<=100。

单词长度K,0<K<1000。

输出描述

输出一个位置下标字符串,拼接格式为:第1个字符行下标+”,”+第1个字符列下标+”,”+第2个字符行下标+”,”+第2个字符列下标… +”,”+第N个字符行下标+”,”+第N个字符列下标。

用例1
输入 4
A,C,C,F
C,D,E,D
B,E,S,S
F,E,C,A
ACCESS
输出 0,0,0,1,0,2,1,2,2,2,2,3
说明 ACCESS分别对应二维数组的[0,0] [0,1] [0,2] [1,2] [2,2] [2,3]下标位置。
考点

dfs

解题思路

本题是考察深度优先搜索的题目,遍历二维数组,找到单词第一个字母所在的位置,开始进行深度优先搜索,比较当前位置的上下左右位置上是否与单词的下一个字母

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2024剑指offer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值