news 2026/3/28 16:20:54

算法讲解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/3/25 0:03:19

震惊!选错云服务器代理商,你的业务将面临巨大风险!

震惊&#xff01;选错云服务器代理商&#xff0c;你的业务将面临巨大风险&#xff01;在数字化转型的浪潮中&#xff0c;云服务器已成为企业业务运行的基石。然而&#xff0c;许多企业在选择服务商时&#xff0c;往往只关注价格或品牌&#xff0c;却忽略了代理商这一关键环节。…

作者头像 李华
网站建设 2026/3/27 7:56:02

软件安装与卸载测试标准化流程指南

1 引言 安装与卸载作为用户接触软件的首末环节&#xff0c;其体验质量直接影响产品形象与用户留存。规范的安装/卸载测试流程是保障软件交付质量、提升用户满意度的关键环节。本规范旨在建立标准化测试框架&#xff0c;明确各阶段测试要点&#xff0c;为测试团队提供完整、可追…

作者头像 李华
网站建设 2026/3/28 4:06:10

书籍-《维特根斯坦文集》

《维特根斯坦文集》详细介绍 书籍基本信息 书名&#xff1a;维特根斯坦文集 作者&#xff1a;路德维希维特根斯坦&#xff08;Ludwig Wittgenstein&#xff0c;1889-1951年&#xff09; 成书时间&#xff1a;1953年&#xff08;遗作首次出版&#xff09;至现代完整版本 卷数&am…

作者头像 李华
网站建设 2026/3/25 22:41:31

20个渗透CTF练习平台资源(2025)

持续学习和实践&#xff0c;是每位安全从业者&#xff0c;尤其是红队成员&#xff0c;保持竞争力的关键。CTF (Capture The Flag&#xff0c;夺旗赛) 和渗透测试练习平台&#xff0c;为我们提供了磨练技能的绝佳环境。 紧接上次的30天渗透测试练习计划&#xff08;2025 第一部…

作者头像 李华
网站建设 2026/3/25 20:43:48

AI营销技术强的机构

AI营销技术强的机构&#xff1a;如何选择并利用优质AI营销服务随着人工智能技术的快速发展&#xff0c;越来越多的企业开始利用AI营销来提升品牌影响力和市场竞争力。然而&#xff0c;在众多提供AI营销技术的机构中&#xff0c;如何选择一家真正具备强大技术和专业能力的机构&a…

作者头像 李华
网站建设 2026/3/25 13:55:15

数据库测试数据的构造策略与全生命周期管理

测试数据在软件质量保障中的关键角色 在软件开发与测试生命周期中&#xff0c;数据库测试数据是验证功能完整性、性能稳定性及安全合规性的基石。尤其对于涉及复杂业务逻辑的系统&#xff0c;如金融、电商或企业级应用&#xff0c;低效或不准确的测试数据可能导致缺陷遗漏、回…

作者头像 李华