题目描述

给一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 单词方阵的更多相关文章

  1. 洛谷 P1101 单词方阵

    题目链接 https://www.luogu.org/problemnew/show/P1101 题目描述 给一n×n的字母方阵,内可能蕴含多个"yizhong"单词.单词在方阵中 ...

  2. 洛谷P1101单词方阵

    题目描述 给一n×n的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的. 摆放可沿着 8个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间可以交叉,因此有 ...

  3. P1101 单词方阵

    题目描述 给一 n \times nn×n 的字母方阵,内可能蕴含多个"yizhong"单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 88 个方向的任一方向,同一单词摆放 ...

  4. P1101 单词方阵(DFS)

    题目描述 给一n \times nn×n的字母方阵,内可能蕴含多个"yizhong"单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 88个方向的任一方向,同一单词摆放时不再 ...

  5. 洛谷P1101 单词方阵——S.B.S.

    题目描述 给一nXn的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着8个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间[color=red ...

  6. P1101 单词方阵 简单dfs

    题目描述 给一n \times nn×n的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 88 个方向的任一方向,同一单词摆放时不再改变方向,单词与单 ...

  7. 洛谷P1101 单词方阵【暴力】【字符串】

    题目描述 给一n×nn \times nn×n的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 888 个方向的任一方向,同一单词摆放时不再改变方向, ...

  8. 洛谷P1101 单词方阵

    题目描述 给一nXn的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着8个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间[color=red ...

  9. 洛谷P1101 单词方阵【DFS】

    给一n \times nn×n的字母方阵,内可能蕴含多个"yizhong"单词.单词在方阵中是沿着同一方向连续摆放的.摆放可沿着 88 个方向的任一方向,同一单词摆放时不再改变方向 ...

随机推荐

  1. pagefile.sys

    pagefile.sys

  2. [RK3288][Android6.0] Display驱动初始化流程小结【转】

    本文转载自:http://blog.csdn.net/kris_fei/article/details/52584903 Platform: RK3288OS: Android 6.0Kernel: ...

  3. mac 下idea光标问题

    可以使用 fn + i 解决此问题

  4. js验证手机号,身份证,车牌号验证

    js验证手机号  <input type="text" class="identificationno"> // 身份证号码为15位或者18位,15 ...

  5. 模块化编程:AMD规范

    目前,通行的Javascript模块规范共有两种:ComonJS和AMD. CommonJS node.js的模块系统,就是参照CommonJS规范实现的.在ConmonJS中,有一个全局方法requ ...

  6. Eclipse 配置 Python 环境

    1.将下载好的Pydev4.5.2(http://sourceforge.net/projects/pydev/files/pydev/  里面有很多版本) 文件夹里的两个文件夹(features+p ...

  7. Classic BADI总结

    这里对sap Classic Badi 做一下总结,虽然已经是过时的技术了. Classic BADI的创建 Classic BADI的实施 Classic BADI的调用及运行原理 New BADI ...

  8. 获取openid [微信小程序]

    public function wxapi(){ $data=$this->requestdata(); if(!$data['code']) exit(json_encode(array('s ...

  9. 295 Find Median from Data Stream 数据流的中位数

    中位数是排序后列表的中间值.如果列表的大小是偶数,则没有中间值,此时中位数是中间两个数的平均值.示例:[2,3,4] , 中位数是 3[2,3], 中位数是 (2 + 3) / 2 = 2.5设计一个 ...

  10. Scala简单计算实例,其在数据分析方面的优势体会

    程序只是简单的从文件中读取数据,并进行计算. package com.bill.www /** * Created by Bill on 2016/2/3. * 目的:用scala实现简单的数据计算 ...