.DFS.

news2024/11/13 8:00:38

DFS

全称为Depth First Search,中文称为深度优先搜索。
这是一种用于遍历或搜索树或图的算法,其思想是:
沿着每一条可能的路径一个节点一个节点地往下搜索,
直到路径的终点,然后再回溯,直到所有路径搜索完为止。

DFS俗称爆搜,最重要的就是顺序
需要思考的是,应该用什么样的顺序来搜索答案
用树的形式展开
假设已经有n个空位了,那么就从第一个开始填,
从前向后一个空位一个空位的填充,且每一次填充的数字不能与前面填充的数字一样
深搜是优先向下走,即先填充好一条路径,填好后,会向前回溯。
每次存的都是当前的路径,回溯后前面的路径就不存在了,
所以整体看来是一棵树,实际上每次只能有一条分支,且最后回溯之后就什么也没了

题目:842. 排列数字 - AcWing题库

 思路:

思路挺简单的:一层for循环,如果当前的数没有被用过,那么就使用它。
st[i]表示当前的数是否被用过
path[x]用来储存将要被使用的数

这里dfs中,dfs的路径表示的是长度,即不断向下深搜
第二个for循环表示的是宽度,即向右深搜,直到找到一个没有被用过的数字。

tips
可以自己模拟一下,但是要注意该层dfs()结束的标志可以是第一层for循环结束,也可以是第二层for循环结束,而且在回溯的过程中,只要存在满足第二层循环里的if(!st[i])语句就会开辟新的路径,向下深搜

 代码:

#include<iostream>

using namespace std;

int path[10];
bool st[10];
int n;

void dfs(int x)
{
    //说明到最后一排——即走完了该条路径
    if(x==n)
    {
        for(int i=0;i<n;i++) cout << path[i] << " ";
        cout << endl;
    }
    else 
    {
        for(int i=1;i<=n;i++)
        {
            //false表示没有被用过
            if(!st[i])
            {
                path[x]=i;//使用i
                st[i]=true;//i被使用过了
                dfs(x+1);
                //清空上一路径的数值以及操作
                path[x]=0;
                st[i]=false;
            }
        }
    }
}
int main()
{
    cin >> n;
    
    dfs(0);
    
    return 0;
}

DFS+剪枝

剪枝,顾名思义就是减去某些枝条且是没用的枝条

返回到DFS中 就是在向下深搜的过程中,如果碰到了与题目要求不符的条件,那就停止向下深搜,转为向前回溯。即可以提前判断当前操作一定是不合法的,那么就没必要继续向下搜了,直接结束,向前回溯。该操作称之为剪枝。

题目:843. n-皇后问题 - AcWing题库

 思路:

题目要求:如果该点已经有皇后了,那么该点所在的行、列,正对角线、反对角线上都不能再有第二个皇后

边深搜便判断是否与题解相斥:如果与题目要求相斥,那么就停止向下搜索,转为向前回溯

不想手动模拟的话,那么可以看一看这一篇题解:AcWing 843. n-皇后问题--图解+代码注释 - AcWing

代码:

#include<iostream>

using namespace std;

const int N=20;
//记录棋盘布局
char cow[N][N];
//l[N]表示这一列是否含有女皇,dg[N]表示该女皇的正对角线是否含有女皇,udg[N]反对角线
int l[N],dg[N],udg[N];
int n;
//深度搜索每一行
void dfs(int u)
{
    if(u==n)
    {
        for(int i=0;i<n;i++)
        {
         for(int j=0;j<n;j++)
              printf("%c",cow[i][j]);
        printf("\n");
        }
        printf("\n");
    }
    
    for(int i=0;i<n;i++)
    {
        //如果满足该女皇所在列、对角线、反对角线都没有别的女皇的话
        if(!l[i] && !dg[u+i] && !udg[n-i+u])
        {
            //则在u行i列放下一个女皇
            cow[u][i]='Q';
            //则新放下女皇所在的列、正对角线、反对角线都不能再放置其他女皇了
            l[i]=dg[u+i]=udg[n-i+u]=true;
            //搜索下一行是否能放置女皇
            dfs(u+1);
            //还原现场
            l[i]=dg[u+i]=udg[n-i+u]=false;
            cow[u][i]='.';
        }
    }
    return;
}

int main()
{
    scanf("%d",&n);
    
    //初始化
    for(int i=0;i<n;i++)
    {
        for(int j=0;j<n;j++)
        cow[i][j]='.';
    }
    
    dfs(0);
    return 0;
}

tips:

dfs强烈建议手动模拟一下,要注意:dfs结束的方式不只是return,还有for循环的结束也会造成dfs的结束。这层dfs结束后就会执行上一个dfs剩下的“还原现场”的语句,接着根据是否结束本层for循环来决定是否结束上一个dfs语句。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1703741.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ComfyUI简单介绍

&#x1f353;什么是ComfyUI ComfyUI是一个为Stable Diffusion专门设计的基于节点的图形用户界面&#xff0c;可以通过各种不同的节点快速搭建自己的绘图工作流程。 软件打开之后是长这个样子&#xff1a; 同时软件本身是github上的一个开源项目&#xff0c;开源地址为&#…

I.MX6ULL Linux C语言开发环境搭建(点灯实验)

系列文章目录 I.MX6ULL Linux C语言开发 I.MX6ULL Linux C语言开发 系列文章目录一、前言二、硬件原理分析三、构建步骤一、 C语言运行环境构建二、软件编写三、链接脚本 四、实验程序编写五、编译下载验证 一、前言 汇编语言编写 LED 灯实验&#xff0c;但是实际开发过程中汇…

Python实现国密GmSSL

Python实现国密GmSSL 前言开始首先安装生成公钥与私钥从用户证书中读取公钥读取公钥生成签名验证签名加密解密 遇到的大坑参考文献 前言 首先我是找得到的gmssl库&#xff0c;经过实操&#xff0c;发现公钥与密钥不能通过pem文件得到&#xff0c;就是缺少导入pem文件的api。这…

maven的下载以及配置的详细教程(附网盘下载地址)

文章目录 下载配置IDEA内部使用配置 下载 1.百度网盘下载 链接: https://pan.baidu.com/s/1LD9wOMFalLL49XUscU4qnQ?pwd1234 提取码: 1234 2.解压即可 配置 1.打开安装文件下conf下的settings.xml文件&#xff0c;我的如下 2.修改配置信息&#xff08;目的是为了修改本地…

【技术分享】Maven常用配置

一、Maven简介 &#xff08;一&#xff09;为什么使用 Maven 由于 Java 的生态非常丰富&#xff0c;无论你想实现什么功能&#xff0c;都能找到对应的工具类&#xff0c;这些工具类都是以 jar 包的形式出现的&#xff0c;例如 Spring&#xff0c;SpringMVC、MyBatis、数据库驱…

MQ本地消息事务表

纯技术方案水文特此记录 MQ本地消息事务表解决了什么问题&#xff1f; MQ本地事务表方案解决了本地事务与消息发送的原子性问题&#xff0c;即&#xff1a;事务发起方在本地事务执行成功后消息必须发出去&#xff0c;否则就丢弃消息。实现本地事务和消息发送的原子性&#xf…

系统安全扫描扫出了:可能存在 CSRF 攻击怎么办

公司的H5在软件安全测试中被检查出可能存在 CSRF 攻击&#xff0c;网上找了一堆解决方法&#xff0c;最后用这种方式解决了。 1、问题描述 CSRF 是 Cross Site Request Forgery的缩写(也缩写为也就是在用户会话下对某个 CGI 做一些 GET/POST 的事&#xff0c;RIVTSTCNNARGO一这…

香橙派AIpro初体验,详解如何安装Home Assistant Supervised

香橙派AIpro&#xff08;OrangePi AIpro&#xff09;开发版&#xff0c;定位是一块AI开发板&#xff0c;搭载的是华为昇腾310&#xff08;Ascend310&#xff09;处理器。 没想到&#xff0c;这几年的发展&#xff0c;AI开发板也逐渐铺开&#xff0c;记得之前看到华为发布昇腾3…

挑战你的数据结构技能:复习题来袭【3】

chap3 练习1 一. 单选题 1. (单选题)栈和队列具有相同的&#xff08;&#xff09; A. 抽象数据类型B. 逻辑结构C. 存储结构D. 运算 答案: B:逻辑结构 答案分析&#xff1a;逻辑结构都属于线性结构,只是它们对数据的运算不同。 2. (单选题)栈是() A. 顺序存储的线性结构B…

深入理解python列表与字典:数据结构的选择与性能差异

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、列表与字典&#xff1a;基础数据结构的对比 二、列表&#xff1a;逐个遍历的查找方式 …

SARscape5.7已经支持3米陆探一号(LT-1)数据处理

SARsacpe5.6.2.1版本已经开始支持LT-1的数据处理&#xff0c;由于当时只获取了12米的条带模式2&#xff08;STRIP2&#xff09;例子数据&#xff0c;对3米条带模式1&#xff08;STRIP1&#xff09;数据的InSAR处理轨道误差挺大&#xff0c;可能会造成干涉图异常。 SARsacpe5.7最…

Android Display Graphics #1 整体框架介绍一

软件基础 Android的framework层提供了一系列的图像渲染API&#xff0c;可绘制2D和3D。简单理解就是上层开发APP的小伙伴提供了接口&#xff0c;开发者可以直接显示对应的自己内容。但如果掌握了Display底层逻辑再写上层app&#xff0c;会有掌控力&#xff0c;出问题可以根据lo…

vs code怎么补全路径,怎么快捷输入文件路径

安装插件&#xff1a; 链接&#xff1a;https://marketplace.visualstudio.com/items?itemNamejakob101.RelativePath 使用 按住 Ctrl Shift H&#xff0c;弹出窗口&#xff0c;输入文件补全&#xff0c;回车就可以了 排除文件 如果你的项目下文件太多&#xff0c;它会…

2000-2017年各省经济政策不确定性指数

2000-2017年各省经济政策不确定性指数 1、时间&#xff1a;2000-2017年 2、来源&#xff1a;国际能源转型学会 3、范围&#xff1a;31省 4、构建说明&#xff1a; 按照Baker等&#xff08;2016&#xff09;的方法&#xff0c;在中国省级范围内构建了经济政策不确定性&…

如果任务过多,队列积压怎么处理?

如果任务过多,队列积压怎么处理? 1、内存队列满了应该怎么办2、问题要治本——发短信导致吞吐量降低的问题不能忽略!!3、多路复用IO模型的核心组件简介1、内存队列满了应该怎么办 如图: 大家可以看到,虽然现在发短信和广告投递,彼此之间的执行效率不受彼此影响,但是请…

快速版-JS基础01书写位置

1.书写位置 2.标识符 3.变量 var&#xff1a;声明变量。 &#xff08;1&#xff09;.变量的重新赋值 &#xff08;2&#xff09;.变量的提升 打印结果&#xff1a;console.log(变量名) 第一个是你写在里面的。 第二个是实际运行的先后之分&#xff0c;变量名字在最前面。变量…

sql注入less8——布尔盲注

sql注入第八关卡是布尔盲注&#xff0c;我们将看不到一般的返回值&#xff0c;只能通过You are in......的消失与否来判断自己输入的字符是否与查询的数据的字符相同&#xff0c;相同则显示You are in......&#xff0c;相反则不显示&#xff0c;如下图所示&#xff1a; 查询语…

每天五分钟深度学习框架pytorch:tensor张量的维度转换大全

本文重点 在深度学习中比较让人头疼的一点就是矩阵的维度,我们必须构建出符合神经网络维度的矩阵,只有将符合要求的矩阵放到神经网络中才可以运行神经网络,本节课程我们将学习以下tensor中维度的变化。 view和shape View和shape,这两个方法可以完成维度的变换操作,而且使…

YOLOv10来了

B站&#xff1a;啥都会一点的研究生公众号&#xff1a;啥都会一点的研究生 前言 YOLOv10 由清华大学研究人员在 Ultralytics版基础上进行进一步开发&#xff0c;引入了一种新的实时目标检测方法&#xff0c;解决了以前版本 YOLO 在后处理和模型架构方面的不足。通过消除非最大…

【WEB前端2024】开源智体世界:乔布斯3D纪念馆-第30课-门的移动动画

【WEB前端2024】开源智体世界&#xff1a;乔布斯3D纪念馆-第30课-门的移动动画 使用dtns.network德塔世界&#xff08;开源的智体世界引擎&#xff09;&#xff0c;策划和设计《乔布斯超大型的开源3D纪念馆》的系列教程。dtns.network是一款主要由JavaScript编写的智体世界引擎…