news 2026/6/23 20:37:35

【深度优先搜索DFS】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【深度优先搜索DFS】

【DFS】

推荐视频链接
推荐好文

核心思想:一条路走到黑,不撞南墙不回头

运用手段:

简述:(推荐好文中有详述)

简单的说,就是对于一个点,我先确定四个方向,当他每次朝我规定的方向走到一个能走的点时,我便先仅仅关注走完后的这个点,再继续走,继续换关注对象。当我关注的这个点走到不能再走的时候,就要返回到上一个点。继续走下一个方向,以此类推,直到找到答案

例题:

1.遍历

代码:

#include<bits/stdc++.h>#defineintlonglongusingnamespacestd;boolG[10][10],s[10][10];//G表地图,s表判定数组(判定是否已经走过了)intd[]={-1,0,1,0,-1};//方向数组intsx,sy,fx,fy;//起点/终点intcns;//答案intn,m,t;voiddfs(intx,inty){if(x==fx&&y==fy)//当到了终点时,答案加一,退回去继续找{cns++;return;}for(inti=1;i<=4;i++)//四个方向{intl=x+d[i],r=y+d[i-1];//方向if(l>=1&&r>=1&&l<=n&&r<=m&&!G[l][r]&&!s[l][r])//不能到地图外去,不能是障碍,不能重复走{s[l][r]=1;//先标记,跟特设起点一个意思dfs(l,r);//关注下一个点s[l][r]=0;//我已经走完了,回去再走的时候就不能说我走过这了}}}signedmain(){cin>>n>>m>>t;cin>>sx>>sy>>fx>>fy;G[sx][sy]=1;//特设起点为障碍,因为每个点只能走一次,如果无特设可能会先上走又下走回到起点再继续往终点走,错误while(t--){intax,ay;cin>>ax>>ay;G[ax][ay]=1;}dfs(sx,sy);cout<<cns;return0;}

2.连通块

#include<bits/stdc++.h>#defineintlonglongusingnamespacestd;charg[110][110];//地图bools[110][110];//判断数组intn,m;intcns;//答案intdx[]={1,1,1,-1,-1,-1,0,0};//方向数组intdy[]={1,0,-1,1,0,-1,1,-1};voiddfs(intx,inty){for(inti=0;i<=7;i++)//8个方向{intsx=x+dx[i],sy=y+dy[i];if(sx>=1&&sx<=n&&sy>=1&&sy<=m&&g[sx][sy]=='W'&&!s[sx][sy])//不能走出地图外,需要是连着的W,并且还不能被标记过{s[sx][sy]=1;//没被标记过,现在标记dfs(sx,sy);//继续找下一个}}}signedmain(){ios::sync_with_stdio(false);cin.tie(0);cin>>n>>m;for(inti=1;i<=n;i++){for(intj=1;j<=m;j++){cin>>g[i][j];}}for(inti=1;i<=n;i++){for(intj=1;j<=m;j++){if(g[i][j]=='W'&&!s[i][j])//如果他是W,并且没有被标记,就说明找到了新的池塘{cns++;//找到了新的池塘s[i][j]=1;//标记他,说明找过了dfs(i,j);}}}cout<<cns<<endl;return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 10:17:27

蓝桥杯JAVA--启蒙之路(三)语句

一前言今天依旧更新有关JAVA基础的知识&#xff0c;唉。自从更新JAVA之后浏览量什么的都下降了&#xff0c;可能是大家也不喜欢这么枯燥的基础学习吧&#xff0c;但是基础还是很重要的&#xff0c;明天和后天可能会停更&#xff0c;因为我要回家了。二主要内容if条件判断&#…

作者头像 李华
网站建设 2026/6/23 19:36:22

金融级情绪识别模型训练全攻略(基于千万级对话数据的优化经验)

第一章&#xff1a;金融客服Agent情绪识别的技术背景与业务价值 在金融服务领域&#xff0c;客户与客服代理&#xff08;Agent&#xff09;之间的交互质量直接影响用户满意度与品牌信任度。随着人工智能技术的发展&#xff0c;尤其是自然语言处理与语音情感分析的进步&#xff…

作者头像 李华
网站建设 2026/6/23 17:45:51

计算机系统基础 bufbomb 实验三

听报告无事&#xff0c;顺手写下做过的实验报告,话不多说&#xff0c;开始正文1、实验目的加深对IA-32函数调用规则和栈帧结构的理解。2、实验原理对目标程序实施缓冲区溢出攻击&#xff0c;通过造成缓冲区溢出来破坏目标程序的栈帧结构&#xff0c;继而执行一些原来程序中没有…

作者头像 李华
网站建设 2026/6/23 17:56:05

Tomcat内存机制以及按场景调优

Tomcat内存机制深度解析与场景化调优 Tomcat作为Java生态中最主流的Web容器&#xff0c;其内存管理直接决定应用的稳定性、响应速度和并发能力。本文将从内存机制底层原理、内存区域划分、常见问题根源&#xff0c;到不同业务场景的调优策略&#xff0c;进行超详细、全维度的拆…

作者头像 李华
网站建设 2026/6/23 19:13:14

ConvertX:自托管的在线文件转换器

ConvertX&#xff1a;自托管的在线文件转换器 在当今信息化时代&#xff0c;文件格式的多样性带来了很多不便。无论是处理文档、图像、视频还是音频&#xff0c;往往需要将文件转换成适合自己需求的格式。为了解决这一问题&#xff0c;ConvertX应运而生&#xff0c;它是一款强大…

作者头像 李华
网站建设 2026/6/22 23:15:38

2025年支持企业实现社会价值与商业价值的战略

在2025年&#xff0c;企业面临的挑战是同时实现社会价值与商业价值。通过创新战略&#xff0c;企业可以有效应对这一挑战。首先&#xff0c;构建以社会责任为核心的商业模式&#xff0c;将信任与责任感融入品牌之中&#xff0c;能够带来更高的顾客忠诚度和市场竞争力。其次&…

作者头像 李华