当前位置: 首页 > news >正文

搜索(DFS BFS)

DFS

常规DFS:

二叉树前序,中序,后序遍历-CSDN博客

void postorderTraversal(root)初始化一个空列表 arrfind访问总树(root,arr)return arrvoid find(temp, arr)if temp 为空return // 调用顺序由前中后序决定find递归访问左子树find递归访问右子树arr加入当前节点

DFS+回溯:

 全排列:

问题 A: 求全排列(1)(DFS(排列类))-CSDN博客

全排列的伪代码(标记,向深搜索,回溯):

void dfs(Node* node) {if (node 是已访问) {return;}标记 node 为已访问;temp.push_back(nums[i]);dfs(nextNode);  //对于 node 的每一个未访问的邻接节点 nextNode temp.pop_back(nums[i]);标记 node 为未访问;
}

 多层嵌套:

 P8650 [蓝桥杯 2017 省 A] 正则问题(dfs )-CSDN博客

def calculate_expression_length():length = 0while True:ch = read_next_character()if ch is None:  # 结束条件,适用于字符串结束return lengthif ch == 'x':length += 1elif ch == '(':length += calculate_expression_length()  # 进入子表达式的递归计算elif ch == ')':return length  # 结束当前递归层次elif ch == '|':length = max(length, calculate_expression_length())  # 开始新的选项计算,并与之前的长度比较

DFS+并查集: 

问题 C: Oil Deposits(DFS+类并查集)-CSDN博客

统计油田数量伪代码:

void dfs(x,y){for i in range(next[i][]):(x,y)向周围八个位置延伸(x1,y1)if (x1,y1) == @:(x1,y1) == *      // 标记dfs(x1,y1)
}

P1141 01迷宫(dfs+染色联通块)-CSDN博客

main()对于每个矩阵中的点 (i, j)如果 visit[i][j] 未标记标记 visit[i][j] 为当前联通块 kDFS探索(i, j)更新联通块 k 的大小为 n        // item[k]对应k个联通块大小k++, 重置 n 为 1void DFS(x, y)(x,y)->四个方向延伸(nx,ny)如果 (nx, ny) 在矩阵范围内 且 map[x][y] ≠ map[nx][ny] 且 visit[nx][ny] 未标记标记 (nx,ny) 为当前联通块 k增加当前联通块的大小 n++DFS(nx, ny)

DFS+断点划分:

P8599 [蓝桥杯 2013 省 B] 带分数(dfs+全排列+断点判断)_洛谷p8599 [蓝桥杯 2013 省 b] 带分数java-CSDN博客 Note:        target=a+b/c        (a,b,c分别由1~9的不同数字组成)

function dfs(position):if position == 9:  # 如果已经填完所有位置# 根据当前排列更新答案returnfor i from 1 to 9:  # 尝试每一个数字if not visited[i]:  # 如果数字i没有被访问过# 标记数字i为已访问arr[position] = i  # 在当前位置放置数字idfs(position + 1)  # 移动到下一个位置# 回溯,标记数字i为未访问function check_condition():# 将arr数组的不同段转换成数字并检查是否满足(l - a) * c == b的条件# 如果条件满足,则增加ans的值

BFS:

保证最短路径:在寻找最短路径问题中,BFS 能够保证一旦找到目标节点,该路径就是最短的。层级遍历:这意味着首先访问距离起点最近的节点,然后依次访问距离逐渐增加的节点。

所以:首次到达任一节点的路径肯定是从起点到该节点的最短路径。

常规BFS:

问题 R: 胜利大逃亡(bfs)-CSDN博客

问题 N: A strange lift(BFS)-CSDN博客

function bfs(x, y, z, T):初始化队列arr将起点{0,0,0,0}加入队列标记起点为已访问while 队列不为空:取出队列首节点为currentif current是终点且val <= T:清空队列输出current.val并返回for 每个可能的移动方向:计算新位置new_posif new_pos有效且未访问且不是墙:标记new_pos为已访问new_pos.val = current.val + 1将new_pos加入队列输出-1  # 没有找到有效路径

http://www.lryc.cn/news/333507.html

相关文章:

  • koc和kol是什么意思?
  • 基于vscode Arduino插件开发Arduino项目
  • AI 驱动强大是视频转换处理软件
  • Python+requests+Pytest+logging+allure+pymysql框架详解
  • 菜鸟笔记-Numpy函数-full/random.randint/random.choice
  • 蓝桥杯每日一题:牛的学术圈I(二分,双指针)
  • fping命令
  • 奇富科技推出新一代全自研智能语音模型,打破沟通壁垒
  • 穿越代码之海:探寻结构体深层逻辑,展望未来应用新天地
  • layui框架实战案例(26):layui-carousel轮播组件添加多个Echarts图标的效果
  • Unity开发一个FPS游戏之三
  • NIUSHOP完美运营版商城 虚拟商品全功能商城 全能商城小程序 智慧商城系统 全品类百货商城
  • vue2开发好还是vue3开发好vue3.0开发路线
  • 爬虫 新闻网站 并存储到CSV文件 以红网为例 V2.0 (控制台版)升级自定义查询关键词、时间段,详细注释
  • JavaSE-11笔记【多线程2(+2024新)】
  • WebKit是什么?
  • 谷歌(Google)历年编程真题——接雨水
  • golang 归并回源策略
  • 【漏洞复现】可视化融合指挥调度平台 dispatch接口处存在任意文件上传漏洞
  • 最讨厌这种字符串问题了!!
  • B-名牌赌王(本人遇到的题,做个笔记)
  • 博客评论回复03
  • 【【萌新的学习之Numpy数组的使用】】
  • RabbitMQ3.13.x之七_RabbitMQ消息队列模型
  • Android JNI 调用第三方SO
  • Vid2seq
  • Opencv人机交互界面设置
  • 蓝桥杯算法心得——字典树考试(贡献度+前缀和)
  • Linux下Qt生成程序崩溃文件
  • Go语言中测试和性能