搜索--P1101 单词方阵
题目描述
给一n×n的字母方阵,内可能蕴含多个“yizhong”单词。单词在方阵中是沿着同一方向连续摆放的。摆放可沿着 8 个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间可以交叉,因此有可能共用字母。输出时,将不是单词的字母用*代替,以突出显示单词。例如:

输入输出格式
输入格式:
第一行输入一个数n。(7≤n≤100)。
第二行开始输入n×n的字母矩阵。
输出格式:
突出显示单词的n×n矩阵。

AC1(以当前所在位置为判断标准)
之前做的搜索,一维上默认就一个方向,二维上可以上下左右,其实就是任意方向,但是本题的方向只能是一条线上的。所以用上一篇走迷宫的搜索是走不通的。
带搜索方向的dfs。方向作为参数传入dfs,可以使用数组提前存储对应方向,1-8散列到对应方向。最后如何保存轨迹呢?设置一个同等大小的二维字符串数组,注意字符数组的默认填充是空(\0),有结束的id(x,y)和方向,逆推就可以了。
结束条件:使用深度depth作为是否成功的标志,字符串yizhong的长度为7,这里设置如果深度为8则看做搜索成功。
搜索条件:如果当前索引没有越界且等于对应的字符,进行下一层的索引,缺点,因为y已经判断过了,所以这里又进行了一次判断 。如果直接对下一层进行判断会少一些操作,同时判断结束条件的depth应为7,对应的解法在AC2
#include<cstdio>
#include<cmath>
using namespace std;
int N;
char strs[101][101];
char ans[101][101];
//8个方向
int xs[8]={1,-1,0,0,1,-1,1,-1};
int ys[8]={0,0,1,-1,1,-1,-1,1};
//标识
char flag[9]=" yizhong";
int num = 0;
void dfs(int i,int j,int depth,int k){
//结束条件
if(depth==8){
for (int l = 7; l > 0; --l) {
i-=ys[k];
j-=xs[k];
ans[i][j]=strs[i][j];//从g开始
}
return;
}
if(i<0||j<0||i>N-1||j>N-1){
return;
}
char is = strs[i][j];
//判断是否为空,当前字符是否符合
if(flag[depth]==is)
dfs(i+ys[k],j+xs[k],depth+1,k);
}
int main() {
scanf("%d", &N);
int temp = 0;
while (temp < N) {
scanf("%s", &strs[temp++]);
}
for (int l = 0; l < N; ++l) {
for (int i = 0; i < N; ++i) {
ans[l][i]='*';
}
}
for (int i = 0; strs[i][0] !='\0'; ++i) {
for (int j = 0; strs[i][j] !='\0'; ++j) {
if(strs[i][j]=='y'){
dfs(i,j,1,0);
dfs(i,j,1,1);
dfs(i,j,1,2);
dfs(i,j,1,3);
dfs(i,j,1,4);
dfs(i,j,1,5);
dfs(i,j,1,6);
dfs(i,j,1,7);
}
}
}
for (int k = 0; k < N; ++k) {
printf("%s\n",ans[k]);
}
return 0;
}
AC2(以下一步为判断标准,更清晰)
#include<cstdio>
#include<cmath>
using namespace std;
int N;
char strs[101][101];
char ans[101][101];
//8个方向
int xs[8]={1,-1,0,0,1,-1,1,-1};
int ys[8]={0,0,1,-1,1,-1,-1,1};
//标识
char flag[9]=" yizhong";
void dfs(int i,int j,int depth,int k){
//结束条件
if(depth==7){
for (int l = 7; l > 0; --l) {
ans[i][j]=strs[i][j];//从g开始
i-=ys[k];
j-=xs[k];
}
return;
}
if(i+ys[k]<0||j+xs[k]<0||i+ys[k]>N-1||j+xs[k]>N-1){
return;
}
char next =strs[i+ys[k]][j+xs[k]];
//判断下一个字符是否符合
if(flag[depth+1]==next)
dfs(i+ys[k],j+xs[k],depth+1,k);
}
int main() {
scanf("%d", &N);
int temp = 0;
while (temp < N) {
scanf("%s", &strs[temp++]);
}
for (int l = 0; l < N; ++l) {
for (int i = 0; i < N; ++i) {
ans[l][i]='*';
}
}
for (int i = 0; strs[i][0] !='\0'; ++i) {
for (int j = 0; strs[i][j] !='\0'; ++j) {
if(strs[i][j]=='y'){
dfs(i,j,1,0);
dfs(i,j,1,1);
dfs(i,j,1,2);
dfs(i,j,1,3);
dfs(i,j,1,4);
dfs(i,j,1,5);
dfs(i,j,1,6);
dfs(i,j,1,7);
}
}
}
for (int k = 0; k < N; ++k) {
printf("%s\n",ans[k]);
}
return 0;
}
搜索--P1101 单词方阵的更多相关文章
- 洛谷 P1101 单词方阵
题目链接 https://www.luogu.org/problemnew/show/P1101 题目描述 给一n×n的字母方阵,内可能蕴含多个"yizhong"单词.单词在方阵中 ...
- 洛谷P1101单词方阵
题目描述 给一n×n的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的. 摆放可沿着 8个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间可以交叉,因此有 ...
- P1101 单词方阵
题目描述 给一 n \times nn×n 的字母方阵,内可能蕴含多个"yizhong"单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 88 个方向的任一方向,同一单词摆放 ...
- P1101 单词方阵(DFS)
题目描述 给一n \times nn×n的字母方阵,内可能蕴含多个"yizhong"单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 88个方向的任一方向,同一单词摆放时不再 ...
- 洛谷P1101 单词方阵——S.B.S.
题目描述 给一nXn的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着8个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间[color=red ...
- P1101 单词方阵 简单dfs
题目描述 给一n \times nn×n的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 88 个方向的任一方向,同一单词摆放时不再改变方向,单词与单 ...
- 洛谷P1101 单词方阵【暴力】【字符串】
题目描述 给一n×nn \times nn×n的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 888 个方向的任一方向,同一单词摆放时不再改变方向, ...
- 洛谷P1101 单词方阵
题目描述 给一nXn的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着8个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间[color=red ...
- 洛谷P1101 单词方阵【DFS】
给一n \times nn×n的字母方阵,内可能蕴含多个"yizhong"单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 88 个方向的任一方向,同一单词摆放时不再改变方向 ...
随机推荐
- SpringMVC_RESTRUL_CRUD
编写POJO Departmet: package org.springmvc.curd.entity; public class Department { private int id; priva ...
- android 反编译 for mac
android反编译现在来说的话很方便. windows上有不好好用的工具,当然我比较喜欢dex2jar 这个是比较好用的,打开他的文件目录会发现,里面有很多.sh .bat文件 那也就是说在wind ...
- uml图六种箭头的含义(转载)
在看一些技术博客的时候,经常会见到博客里画上很多uml图.因为经常会被这几种表达关系的箭头搞混,这里我就把常见的6种箭头表达的含义理一下. 泛化 概念:泛化是一种一般与特殊.一般与具体之间关系的描述, ...
- 栗染-Myeclispe连接SQL Server数据库
第一步,在SQL server方面 这里是以身份验证登录. 这里我是建了一个hw的数据库,其他没啥说的. 第二步,最主要的一部分 因为第一次连接SQL Server数据库,所以就不知道还有这一步.不然 ...
- 13、git
安装Git 网上有很多Git安装教程,如果需要图形界面,windows下建议使用TortoiseGit,linux建议使用Git GUI或者GITK.(windows下载exe安装包,linux可以使 ...
- 【杂文】5亿大质数表(5e8)
[杂文]\(5\) 亿大质数表(\(5e8\)) 在写哈希,刷数论题时曾一度想要查质数,\(F**k\) 百度文库数据又少,翻页蛋疼,还不给复制,真的是服了. 于是在我闲的蛋疼的时候就搞了个质数表出来 ...
- 状态压缩+枚举 POJ 3279 Fliptile
题目传送门 /* 题意:问最少翻转几次使得棋子都变白,输出翻转的位置 状态压缩+枚举:和之前UVA_11464差不多,枚举第一行,可以从上一行的状态知道当前是否必须翻转 */ #include < ...
- 374 Guess Number Higher or Lower 猜数字大小
我们正在玩一个猜数字游戏. 游戏规则如下:我从 1 到 n 选择一个数字. 你需要猜我选择了哪个数字.每次你猜错了,我会告诉你这个数字是大了还是小了.你调用一个预先定义好的接口 guess(int n ...
- 【C++】Item34.区分接口继承和实现继承
区分接口继承和实现继承 类包含的成员函数种类 1.静态函数 2.非静态函数 2.1 普通函数(非虚) non-virtual 2.2 虚函数 2.2.1 纯虚函数 pure-virtual 2.2.2 ...
- 151. [USACO Dec07] 建造路径
★★ 输入文件:roads.in 输出文件:roads.out 简单对比 时间限制:1 s 内存限制:128 MB 译 by CmYkRgB123 描述 Farmer John 刚刚得 ...