题目描述

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

输入:
8 输出:
qyizhong *yizhong
gydthkjy gy******
nwidghji n*i*****
orbzsfgz o**z****
hhgrhwth h***h***
zzzzzozo z****o**
iwdfrgng i*****n*
yyyygggg y******g

输入输出格式

输入格式:

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

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

输出格式:

突出显示单词的n×nn \times nn×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

题意:

给定一个n*n的字符矩阵,问能不能在行、列、对角线一共八个方向中找到字符串"yizhong"

把所有除"yizhong"之外的字符变成‘*’

思路:

数据量只有100,所以随便怎么暴力都行

 //#include<bits/stdc++>
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<stdlib.h>
#include<queue>
#include<map>
#include<stack>
#include<set> #define LL long long
#define ull unsigned long long
#define inf 0x3f3f3f3f using namespace std;
int n;
const int maxn = ;
string ch[maxn];
bool yes[maxn][maxn]; int main()
{
scanf("%d", &n);
for(int i = ; i < n; i++){
cin>>ch[i];
} for(int i = ; i < n; i++){
for(int j = ; j <= n - ; j++){
string tmp = "";
for(int k = ; k < ; k++){
tmp += ch[i][j + k];
}
if(tmp == "yizhong"){
for(int k = ; k < ; k++){
yes[i][j + k] = true;
}
}
}
for(int j = n - ; j >= ; j--){
string tmp = "";
for(int k = ; k < ; k++){
tmp += ch[i][j - k];
}
if(tmp == "yizhong"){
for(int k = ; k < ; k++){
yes[i][j - k] = true;
}
}
}
} for(int i = ; i < n; i++){
for(int j = ; j <= n - ; j++){
string tmp = "";
for(int k = ; k < ; k++){
tmp += ch[j + k][i];
}
if(tmp == "yizhong"){
for(int k = ; k < ; k++){
yes[j + k][i] = true;
}
}
}
for(int j = n - ; j >= ; j--){
string tmp = "";
for(int k = ; k < ; k++){
tmp += ch[j - k][i];
}
if(tmp == "yizhong"){
for(int k = ; k < ; k++){
yes[j - k][i] = true;
} }
}
} for(int i = ; i <= n - ; i++){
for(int j = -n + + i; j <= i; j++){
string tmp = "";
for(int k = ; k < ; k++){
tmp += ch[i + k][i + k - j];
}
if(tmp == "yizhong"){
for(int k = ; k < ; k++){
yes[i + k][i + k - j] = true;
}
}
}
}
for(int i = n - ; i >= ; i--){
for(int j = -n + + i; j <= i; j++){
string tmp = "";
for(int k = ; k < ; k++){
tmp += ch[i - k][i - k - j];
}
if(tmp == "yizhong"){
for(int k = ; k < ; k++){
yes[i - k][i - k - j] = true;
}
}
}
} for(int i = ; i <= n - ; i++){
for(int j = n - ; j >= ; j--){
string tmp = "";
for(int k = ; k < ; k++){
tmp += ch[i + k][n - - i - k];
}
if(tmp == "yizhong"){
for(int k = ; k < ; k++){
yes[i + k][n - - i - k] = true;
}
}
}
}
for(int i = n - ; i >= ; i--){
for(int j = ; j <= n - ; j++){
string tmp = "";
for(int k = ; k < ; k++){
tmp += ch[i - k][n - - i + k];
}
if(tmp == "yizhong"){
for(int k = ; k < ; k++){
yes[i - k][n - - i - k] = true;
} }
}
} for(int i = ; i < n; i++){
for(int j = ; j < n; j++){
if(yes[i][j]){
printf("%c", ch[i][j]);
}
else{
printf("*");
}
}
printf("\n");
}
return ;
}

洛谷P1101 单词方阵【暴力】【字符串】的更多相关文章

  1. 洛谷 P1101 单词方阵

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

  2. 洛谷——P1101 单词方阵

    https://www.luogu.org/problem/show?pid=1101#sub 题目描述 给一nXn的字母方阵,内可能蕴含多个“yizhong”单词.单词在方阵中是沿着同一方向连续摆放 ...

  3. 洛谷P1101单词方阵

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

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

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

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

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

  6. 洛谷P1101 单词方阵

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

  7. 洛谷 P1101单词方阵

    我已经,是这个世界上,最幸福的女孩了                                                                         ——<末日时 ...

  8. 集训作业 洛谷P1101 单词方阵

    这个题的长度真的有点长,我直接放图片吧 这个题又是一个和谐的搜索,找到yizhong的y就开始8面搜索,遇见正确的字母就继续搜索,不正确就果断放弃,果然又是一个和谐的搜索呢. #include< ...

  9. 洛谷1019 单词接龙 字符串dfs

    问题描述 单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相连时,其重合 ...

随机推荐

  1. 基于Centos搭建 Firekylin 个人网站

    系统要求: CentOS 7.2 64 位操作系统 安装 Node.js 使用 yum 命令安装 Node.js curl --silent --location https://rpm.nodeso ...

  2. c链表之oc AutoReleasePool

    直接贴 原文吧: http://blog.sunnyxx.com/2014/10/15/behind-autorelease/

  3. vue项目使用webpack loader把px转换为rem

    下载lib-flexible https://github.com/amfe/lib-flexible npm i lib-flexible --save 在main.js中引入lib-flexibl ...

  4. 开始逐步补充下相关Web知识,很多年没搞了....

    <script type="text/javascript"> $(function(){ ShowProduct(); $("#ShowUserInfo&q ...

  5. Java连接各种数据库写法

    # 示例配置参考,涵盖几乎所有的主流数据库 ############# Oracle数据库 ######################## #   数据库驱动名 driver=oracle.jdbc ...

  6. EntLib 自动数据库连接字符串加密

    const string provider = "RsaProtectedConfigurationProvider"; Configuration config = null; ...

  7. WebRTC信令控制简介与STUN, TURN服务器搭建

    本文将向大家介绍两个方面的知识: WebRTC信令控制 STUN/TURN服务器的搭建 在前面的文章中已经向大家介绍了如何构建信令服务器.但构建的信令服务器是如何工作的?哪些消息需要信令服务器控制和中 ...

  8. Asp.net Daily Build by MsBuild

    :: 目录结构:: +GW.Point.BLL --dir dll:: +GW.Point.IBLL --dir dll:: +GW.Point.DAL --dir dll:: +GW.Point.I ...

  9. Java知多少(23)类的基本运行顺序

    我们以下面的类来说明一个基本的 Java 类的运行顺序: public class Demo{ private String name; private int age; public Demo(){ ...

  10. Java知多少(33)多态对象的类型转换

    这里所说的对象类型转换,是指存在继承关系的对象,不是任意类型的对象.当对不存在继承关系的对象进行强制类型转换时,java 运行时将抛出 java.lang.ClassCastException 异常. ...