题目描述
给一 n×n 的字母方阵,内可能蕴含多个 yizhong
单词。单词在方阵中是沿着同一方向连续摆放的。摆放可沿着 88 个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间可以交叉,因此有可能共用字母。输出时,将不是单词的字母用 *
代替,以突出显示单词。
洛谷链接给上
https://www.luogu.com.cn/problem/P1101
输入格式
第一行输入一个数 n。(7≤n≤100)。
第二行开始输入 n×n 的字母矩阵。
输出格式
突出显示单词的 n×n 矩阵。
输入输出样例
输入 #1
7 aaaaaaa aaaaaaa aaaaaaa aaaaaaa aaaaaaa aaaaaaa aaaaaaa
输出 #1
******* ******* ******* ******* ******* ******* *******
输入 #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
题目思路
这题思路简单,是个简单的搜索题。当时做的时候本来还以为要优化,结果直接一遍过了哈哈;
按照题意,遍历一遍矩阵,然后每遇到y这个字母就开始匹配,看它的八个方向直线过于有没有符合yizhong这个字符串,如果符合,标记上就行了哈哈;记得范围标注清楚哈;
代码附上
#include<bits/stdc++.h>
using namespace std;
#define int long long
char mp[105][105];
int vis[105][105],n;
int d[8][2] ={-1,-1, -1,1, 1,-1, 1,1, -1,0, 1,0, 0,-1, 0,1};
char dd[] = {"yizhong"};
void bfs(int x,int y)
{
for(int i = 0;i<8;i++){
if(x+6*d[i][0]>0&&y+6*d[i][1]>0
&&x+6*d[i][0]<=n&&y+6*d[i][1]<=n){
string s;
for(int j = 0;j<7;j++){
s+=mp[x+d[i][0]*j][y+d[i][1]*j];
}
if(s==dd)
for(int j = 0;j<7;j++){
vis[x+d[i][0]*j][y+d[i][1]*j] = 1;
}
}
}
}
signed main()
{
// ios::sync_with_stdio(false);
cin >> n;
for(int i = 1;i<=n;i++){
for(int j = 1;j<=n;j++){
scanf("\n%c",&mp[i][j]);
}
}
for(int i = 1;i<=n;i++){
for(int j = 1;j<=n;j++){
if(mp[i][j]=='y')bfs(i,j);
}
}
for(int i = 1;i<=n;i++){
for(int j = 1;j<=n;j++){
if(vis[i][j]==0)cout << "*";
else cout << mp[i][j];
}
cout << endl;
}
}