题解报告:P1101 单词方阵(dfs+方向搜索)

简介: 算法

飞机票


题意:

7.png

思路:

搜索从y开始的八个方向看看能不能搜到yizhong搜到了就标机,然后输出标机的字符即可

#include<bits/stdc++.>
using namespace std;
const int maxn=105;
int n;
char c1[maxn][maxn];
char ans[8]={'y','i','z','h','o','n','g'};
int x1[9]={0,1,0,1,-1,0,-1,1,-1};
int y11[9]={0,0,1,1,0,-1,-1,-1,1};
bool f[maxn][maxn];
struct {
    int x,y;
}mo[8];
bool jg(int x,int y){
    if(x>=1&&x<=n&&y>=1&&y<=n){
        return true;
    }
    else
        return false;
}
void dfs(int x,int y ,int cnt,int wx,int wy){
   int i,j;
   if(cnt==6){
        for(i=0;i<7;i++){
            f[mo[i].x][mo[i].y]=1;
        }
   }
   if(wx==0&&wy==0){
         for(i=1;i<=8;i++){
                    j=i;
                    int xx=x+x1[i]; int yy=y+y11[j];
                     if(jg(xx,yy)==1&&c1[xx][yy]==ans[cnt+1]){
                         mo[cnt+1].x=xx,mo[cnt+1].y=yy;
                        dfs(xx,yy,cnt+1,x1[i],y11[j]);
                    }
        }
   }
   else {
         int xx=x+wx; int yy=y+wy;
            if(jg(xx,yy)==1&&c1[xx][yy]==ans[cnt+1]){
                        mo[cnt+1].x=xx,mo[cnt+1].y=yy;
                        dfs(xx,yy,cnt+1,wx,wy);
            }
   }
}
int main()
{
    int i,j,t;
    cin>>n;
    getchar();
    for(i=1;i<=n;i++){
        for(j=1;j<=n;j++){
               cin>>c1[i][j];
        }
    }
    for(i=1;i<=n;i++){
        for(j=1;j<=n;j++){
               if(c1[i][j]=='y'){
                    mo[0].x=i;
                    mo[0].y=j;
                    dfs(i,j,0,0,0);
               }
        }
    }
    for(i=1;i<=n;i++){
        for(j=1;j<=n;j++){
            if(f[i][j]==0) cout<<"*";
            else cout<<c1[i][j];
        }
        cout<<endl;
    }
    return 0;
}
相关文章
|
存储 弹性计算 固态存储
阿里云存储价格100GB/1TB/50TB/500GB空间费用大全
阿里云云存储怎么收费?云存储1GB空间容量多少钱?如果是OSS对象存储1GB价格是0.12元/GB/月,标准存储包1TB一年价格999元;NAS文件存储100GB价格是30元一个月,500G空间150元/月;块存储高效云盘40G空间14元/月
24373 0
阿里云存储价格100GB/1TB/50TB/500GB空间费用大全
|
Web App开发 Android开发 iOS开发
|
4天前
|
云安全 人工智能 安全
AI被攻击怎么办?
阿里云提供 AI 全栈安全能力,其中对网络攻击的主动识别、智能阻断与快速响应构成其核心防线,依托原生安全防护为客户筑牢免疫屏障。
|
14天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
8天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
572 211
|
4天前
|
编解码 Linux 数据安全/隐私保护
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
229 138
|
存储 人工智能 监控
从代码生成到自主决策:打造一个Coding驱动的“自我编程”Agent
本文介绍了一种基于LLM的“自我编程”Agent系统,通过代码驱动实现复杂逻辑。该Agent以Python为执行引擎,结合Py4j实现Java与Python交互,支持多工具调用、记忆分层与上下文工程,具备感知、认知、表达、自我评估等能力模块,目标是打造可进化的“1.5线”智能助手。
811 59
|
6天前
|
人工智能 移动开发 自然语言处理
2025最新HTML静态网页制作工具推荐:10款免费在线生成器小白也能5分钟上手
晓猛团队精选2025年10款真正免费、无需编程的在线HTML建站工具,涵盖AI生成、拖拽编辑、设计稿转代码等多种类型,均支持浏览器直接使用、快速出图与文件导出,特别适合零基础用户快速搭建个人网站、落地页或企业官网。
1139 157