洛谷:P1101 单词方阵

单词方阵

题目描述

给一 n × n n \times n n×n 的字母方阵,内可能蕴含多个 yizhong 单词。单词在方阵中是沿着同一方向连续摆放的。摆放可沿着 8 8 8 个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间可以交叉,因此有可能共用字母。输出时,将不是单词的字母用 * 代替,以突出显示单词。

输入格式

第一行输入一个数 n n n。 ( 7 ≤ n ≤ 100 ) (7 \le n \le 100) (7≤n≤100)。

第二行开始输入 n × n n \times n n×n 的字母矩阵。

输出格式

突出显示单词的 n × n n \times n n×n 矩阵。

样例 #1

样例输入 #1

复制代码
7
aaaaaaa
aaaaaaa
aaaaaaa
aaaaaaa
aaaaaaa
aaaaaaa
aaaaaaa

样例输出 #1

复制代码
*******
*******
*******
*******
*******
*******
*******

样例 #2

样例输入 #2

复制代码
8
qyizhong
gydthkjy
nwidghji
orbzsfgz
hhgrhwth
zzzzzozo
iwdfrgng
yyyygggg

样例输出 #2

复制代码
*yizhong
gy******
n*i*****
o**z****
h***h***
z****o**
i*****n*
y******g

dfs

这个题感觉应该用dfs,不过在写dfs中可以有不同写法,此处我现在主函数找到y在进dfs搜索,把y的8个方向全试一遍,有的话就更改到vis数组中。

最后输出的时候vis的位置如果是0就是无用位置,输出*即可。

cpp 复制代码
#include<bits/stdc++.h>
//#include<iostream>
//#include<iomanip>
//#include<vector>
//#include<queue>
//#include<algorithm>
#define rep(i,l,r) for(int i=l;i<=r;i++)
using namespace std;
#define pii pair<int,int>
#define endl '\n'
const int M=2e5+7;
char  a[200][200];
char vis[200][200];
int dx[8]={-1,0,1,0, -1,1,1,-1};
int dy[8]={0,1,0,-1, 1,1,-1,-1  };
int n,m;
//int qix,qiy,zx,zy;
int ant=0;
string s="yizhong";
vector<pii> v;
void  dfs(int x,int y)
{
 for(int i=0;i<8;i++)
 {
    v.push_back({x,y});  //将坐标放进数组,最后若满足再更改
    int xx=x+dx[i],yy=y+dy[i];
    int j=1;
     while(xx>0&&xx<=n&&yy>0&&yy<=n&&j<7&&s[j]==a[xx][yy])
     {//注意边界条件在界内
         v.push_back({xx,yy});
         xx+=dx[i],yy+=dy[i];
        j++;
     }
    
   if(j>=7){
     for(int i=0;i<v.size();i++)
      {
        int fir=v[i].first,sec=v[i].second;
        vis[fir][sec]=s[i];
      }
    }
  v.clear();  //清空,方便下一次搜索
 }
}


int main()
{
std::ios::sync_with_stdio(false);
cin.tie(0);cout.tie(0);
cin>>n;
rep(i,1,n)rep(j,1,n)cin>>a[i][j];

rep(i,1,n)rep(j,1,n)
{
  if(a[i][j]=='y')
  dfs(i,j);
}

rep(i,1,n)
{rep(j,1,n)
{
  if(vis[i][j]==0)cout<<'*';
  else cout<<vis[i][j];
}
cout<<endl;
}
return 0;
}
相关推荐
山甫aa8 分钟前
List 容器 -----C++的stl学习
开发语言·c++·学习
汀、人工智能8 分钟前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo13 分钟前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ015 分钟前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法
森G25 分钟前
58、最佳实践与注意事项---------多线程、竟态条件和同步
c++·qt
汀、人工智能27 分钟前
[特殊字符] 第76课:单词拆分
数据结构·算法·均值算法·前缀树·trie·单词拆分
CheerWWW30 分钟前
C++学习笔记——箭头运算符、std::vector的使用、静态链接、动态链接
c++·笔记·学习
Fcy6481 小时前
算法基础详解(五)二分算法——二分查找与二分答案
算法·二分算法
郭涤生1 小时前
原子操作的内存顺序
c++
ALex_zry1 小时前
C++模板元编程实战技巧
网络·c++·windows