news 2026/5/26 8:22:56

算法讲解8:搜索之bfs(广度优先)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法讲解8:搜索之bfs(广度优先)

搜索:穷尽所有的可能找到最优解,或统计和法解的个数

分类:dfs,bfs

特点:有多种优化方式,如减小状态空间,更改搜索顺序,剪枝等

对于bfs,每次都先处理该层图层

例题:

题目描述

小 A 有一棵 n 个结点的树,这些结点依次以 1,2,⋯,n 标号。

小 A 想在这棵树上漫步。具体来说,小 A 会从树上的某个结点出发,每一步可以移动到与当前结点相邻的结点,并且小 A 只会在偶数步(可以是零步)后结束漫步。

现在小 A 想知道,对于树上的每个结点,从这个结点出发开始漫步,经过偶数步能结束漫步的结点有多少个(可以经过重复的节点)。

输入格式

第一行,一个正整数 n。

接下来 n−1 行,每行两个整数 ui​,vi​,表示树上有⼀条连接结点 ui​ 和结点 vi​ 的边。

输出格式

一行,n 个整数。第 i 个整数表示从结点 i 出发开始漫步,能结束漫步的结点数量。

输入输出样例

输入 #1复制

3 1 3 2 3

输出 #1复制

2 2 1
import java.util.*;//一次性等于使用所有util的 //树是二分图(无奇环),任意两点的路径长度奇偶性固定 //需要二分 //- 同层节点(如偶-偶、奇-奇):层数差为0(偶数)→ 路径长度必为偶数; //- 异层节点(如偶-奇):层数差为1(奇数)→ 路径长度必为奇数; public class p11962 { static List<List<Integer>> adj;//邻接表 static int[] color; static int cnt0,cnt1;//静态修饰的默认为0 public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); adj = new ArrayList<>();//对邻接表的初始化 for (int i = 0; i <= n; i++) adj.add(new ArrayList<>());//每次循环给外层列表adj添加一个新的空arraylist,整体是邻接表的内层初始化 for (int i = 0; i < n-1; i++) { int u = sc.nextInt(), v = sc.nextInt(); adj.get(u).add(v);//节点u的相邻节点包含v adj.get(v).add(u);//就相当于一切的基础,相当于1棵树,不过两者相互连结需要在后面用 if (color[v] == -1)来保持正常 } color = new int[n+1]; Arrays.fill(color, -1);//将数组中所有的元素都初始化为-1 bfs(1); // 从节点1开始染色 // 输出每个节点的结果 for (int i = 1; i <= n; i++) { System.out.print((color[i] == 0 ? cnt0 : cnt1) + " "); }//color[i]=0说明是偶数分组,该组有几个就输出几个 //color=0 说明当前节点属于“偶层分组”,而偶层分组的所有节点,都能通过偶数步到达当前节点 //color=1 时,输出的是 cnt1 ——因为 color=1 表示当前节点属于“奇层分组”,该分组的所有节点都能通过偶数步到达当前节点, // cnt1 正是这个分组的总节点数。 } static void bfs(int start) {//广度优先搜索 Queue<Integer> q = new LinkedList<>(); q.add(start);//1.队列的作用:维持“待处理节点”顺序,确保先处理父节点、再处理子节点(符合树的层级遍历逻辑); color[start] = 0; cnt0++; while (!q.isEmpty()) {//队列不为空就持续染色 int u = q.poll();//取出头部,poll是取出并移除 for (int v : adj.get(u)) {//adj.u代表的是与节点u相邻的所有节点,整体上市遍历节点u相邻的所有节点后赋值给v if (color[v] == -1) {//保证只能被染色一次,想想之前输入的时候队adj做的,想象树从上往下找,这行代码就杜绝从下往上的可能 color[v] = color[u] ^ 1; // 0^1=1,1^1=0---v一定与u相邻,这行本质上就是,给v和u相反的颜色 if (color[v] == 0) cnt0++;//计数 else cnt1++; q.add(v);//这个队列在for循环的时候一直加 } } } } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 23:16:35

PySpark实战 - 2.2 利用Spark SQL计算总分与平均分

文章目录1. 实战概述2. 实战步骤3. 实战总结1. 实战概述 本次实战基于 Spark SQL 对 HDFS 上的学生成绩文本文件进行分析&#xff0c;通过 split 函数拆分姓名与各科成绩&#xff0c;利用嵌套查询和聚合计算&#xff0c;实现每位学生的总分与保留一位小数的平均分统计&#xf…

作者头像 李华
网站建设 2026/5/25 23:03:17

未来之窗昭和仙君(五十六)页面_预览模式——东方仙盟筑基期

未来之窗昭和仙君 - 一、功能概述此页面_预览模式功能用于将页面中的特定输入框转换为只读状态&#xff0c;呈现出预览模式。该功能支持对多种输入框类型进行处理&#xff0c;默认处理文本框、日期框和数字框&#xff0c;也可以自定义输入框类型。在处理时&#xff0c;会将输入…

作者头像 李华
网站建设 2026/5/26 0:06:55

第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第一赛季优化题--无人机配送

前言 “全球校园人工智能算法精英大赛”是江苏省人工智能学会举办的面向全球具有正式学籍的全日制高等院校及以上在校学生举办的算法竞赛。其中的算法巅峰赛属于产业命题赛道&#xff0c;这是第一赛季&#xff0c;对最后一道优化题进行浅浅地解读。 无人机配送 问题描述 低空…

作者头像 李华
网站建设 2026/5/26 1:20:38

CTF 大神才知道的 50 个解题骚套路,速速收藏!_ctf解题思路模板

CTF 大神才知道的 50 个解题骚套路&#xff0c;速速收藏&#xff01; CTF 竞赛的核心玩法 核心目标 &#xff1a; 以 Flag 为导向&#xff0c;光速拆解问题、熟练运用各种工具、培养模式化思维。 关键原则 &#xff1a; 先撒网再深挖&#xff08;信息收集要全面&#xff09;、…

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

白盒测试与代码覆盖率:从理论到实践的全方位解析

在软件开发的生命周期中&#xff0c;测试是确保产品质量的关键环节。白盒测试&#xff08;White-Box Testing&#xff09;&#xff0c;又称结构测试或玻璃盒测试&#xff0c;是一种基于程序内部逻辑和代码结构的测试方法。它与代码覆盖率&#xff08;Code Coverage&#xff09;…

作者头像 李华