news 2026/5/17 3:20:42

【深度优先搜索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/5/16 19:27:51

【毕业设计】基于springboot+微信小程序的集换社卡牌的交易系统小程序(源码+文档+远程调试,全bao定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/9 21:14:11

计算机小程序毕设实战-基于SpringBoot的交通违法有奖曝光平台设计与基于springboot+微信小程序的的交通违法有奖曝光平台【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/10 21:21:36

HTML行内块标签——img、表单、音视频标签

目录 概念&#xff1a;特殊的标签&#xff0c;有自己独有的功能 img标签&#xff1a; 表单&#xff1a; 1、input表单项 2、下拉框表单项:select 3、内容框&#xff1a;textarea 4、按钮 button 5、去除表单默认样式 ​编辑 音视频标签 概念&#xff1a;特殊的标签&a…

作者头像 李华
网站建设 2026/5/14 13:20:00

微信ipad协议,wechatapi,个人号二次开发

微信生态安全挑战与防护策略微信作为拥有13亿月活用户的平台&#xff0c;其安全体系具有高度复杂性。未经优化的自动化工具面临极高封号风险&#xff1a;第一周35%、一个月65%、三个月85%、六个月95%。微信风控系统技术原理设备层防护 微信采集50设备特征参数&#xff0c;包括硬…

作者头像 李华
网站建设 2026/5/12 7:33:26

MyBatis/MyBatis-Plus类型转换器深度解析:从基础原理到自定义实践

目录前言基本概念一、TypeHandlerTypeHandler作用内置 TypeHandler 的自动映射二、jdbcType 的必要性&#xff1a;处理 NULL 值的核心三、自定义 TypeHandler前言 这篇博客主要讲一下mybatis/mybatisplus框架的类型转换器的相关知识和用法&#xff0c;最近项目有一个技术场景&…

作者头像 李华
网站建设 2026/5/7 21:35:20

sql server自动备份

1.在管理中点击维护计划向导 2.填写任务名称&#xff0c;点击更改 3.选择需要的备份时间&#xff0c;点击确定 4.勾选备份完整数据库 5.点击下一步 6.选择指定数据库 7.选择备份路径 8.选择完成后点击下一步 9.选择清除任务 10.点击下一步 11.点击完成 12.点击执行任务测试是否…

作者头像 李华