树的深搜和广搜

树的深搜:

树的重心

思路:我们可以遍历每一个节点,获取当前节点除外以后的每一个连通块中的点的数量,用一个res变量存储,每次到最后的时候用一个ans存储res中的最小值。

 1 #include <iostream>
 2 #include <algorithm>
 3 #include <cstring>
 4
 5 using namespace std;
 6
 7 const int N = 1e5+10;
 8
 9 int e[2 * N], ne[2 * N], h[N], idx;
10 bool st[N];
11 int n;
12 int ans = N;
13
14 void add(int a, int b)
15 {
16     e[idx] = b, ne[idx] = h[a], h[a] = idx ++;
17 }
18
19 int dfs(int u)
20 {
21     st[u] = true;//标记此点已被搜过
22
23     int sum = 1, res = 0;//sum表示加上当前节点和其子树的节点数个数,因为至少有自己一个节点,所以初始为1
24     for(int i = h[u] ; ~i ; i = ne[i])//遍历子节点
25     {
26         int j = e[i];
27         if(!st[j])//没有访问过
28         {
29             int s = dfs(j);//s表示当前节点所在连通块节点总数
30             res = max(res, s);//与子树节点作比较取最大
31             sum += s;//将子树节点个数加入sum
32         }
33     }
34     res = max(res, n - sum);//与上方的节点取最大值
35
36     ans = min(ans, res);//按要求求最小的值
37
38     return sum;//将以此节点为根的树的节点总数返回
39 }
40
41 int main(){
42     cin >> n;
43
44     memset(h, -1, sizeof h);
45
46     for(int i = 0 ; i < n ; i ++)
47     {
48         int a, b;
49         cin >> a >> b;
50         add(a, b), add(b, a);
51     }
52
53     dfs(1);//随便找一个点开始搜索
54
55     cout << ans << endl;
56
57     return 0;
58 }

树的广搜:

运用广搜搜图或者树,就是层次遍历。类似与求解迷宫最短路径,可以先将表示距离的d数组初始化为-1,这样就不需要再开一个st数组记录是否访问过该点,如果该点的dis是-1就说明还未访问过。然后就是普通的广搜。

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <iostream>
 4 #include <algorithm>
 5 #include <queue>
 6
 7 using namespace std;
 8
 9 const int N = 100010;
10
11 int n, m;
12 int h[N], e[N], ne[N], idx;
13 int d[N];
14
15 void add(int a, int b)
16 {
17     e[idx] = b, ne[idx] = h[a], h[a] = idx ++ ;
18 }
19
20 int bfs()
21 {
22     memset(d, -1, sizeof d);//初始化
23
24     queue<int> q;
25     d[1] = 0;
26     q.push(1);
27
28     while (q.size())
29     {
30         int t = q.front();
31         q.pop();
32
33         for (int i = h[t]; ~i ; i = ne[i])
34         {
35             int j = e[i];
36             if (d[j] == -1)//如果该节点未访问就访问
37             {
38                 d[j] = d[t] + 1;
39                 q.push(j);//将其加入队列
40             }
41         }
42     }
43
44     return d[n];
45 }
46
47 int main()
48 {
49     scanf("%d%d", &n, &m);
50     memset(h, -1, sizeof h);
51
52     for (int i = 0; i < m; i ++ )
53     {
54         int a, b;
55         scanf("%d%d", &a, &b);
56         add(a, b);
57     }
58
59     cout << bfs() << endl;
60
61     return 0;
62 }

原文地址:https://www.cnblogs.com/1-0001/p/12228356.html

时间: 2024-10-10 09:32:24

树的深搜和广搜的相关文章

看数据结构写代码(39) 图的遍历(深搜和广搜)

图的遍历算法 有两种 :深度优先搜索遍历 和 广度 优先搜索遍历.深度优先搜索遍历类似与 树的 先序遍历.广度优先搜索遍历类似与树的层序遍历.只不过 图 可以有 不连通的 节点,所以 得 遍历 整个顶点数组. 深搜遍历 总是 先访问当前节点的邻接点,而 广搜算法 是 先访问顶点的邻接点 要 先于 后访问顶点的邻接点 被 访问. 具体遍历顺序如下: 以下代码 以 图的 邻接多重表 为 基本结构进行 遍历. 首先更改 上节 的 查找 邻接点 和 下一个邻接点的 返回值,以及 邻接点的 代码 有误,少

深搜和广搜的原理及优缺点

原文来源:https://blog.csdn.net/dark_cy/article/details/88926435 深搜原理深搜,顾名思义,是深入其中.直取结果的一种搜索方法. 如果深搜是一个人,那么他的性格一定倔得像头牛!他从一点出发去旅游,只朝着一个方向走,除非路断了,他绝不改变方向!除非四个方向全都不通或遇到终点,他绝不后退一步!因此,他的姐姐广搜总是嘲笑他,说他是个一根筋.不撞南墙不回头的家伙. 深搜很讨厌他姐姐的嘲笑,但又不想跟自己的亲姐姐闹矛盾,于是他决定给姐姐讲述自己旅途中的经

宽搜和广搜、

广搜与深搜的小区别 一般来说,广搜常用于找单一的最短路线,或者是规模小的路径搜索,它的特点是"搜到就是最优解", 而深搜用于找多个解或者是"步数已知(好比3步就必需达到前提)"的标题,它的空间效率高,然则找到的不必定是最优解,必需记实并完成全数搜索,故一般情况下,深搜需要很是高效的剪枝(优化). 像搜索最短路径这些的很显著若是用广搜,因为广搜的特征就是一层一层往下搜的,保证当前搜到的都是最优解,当然,最短路径只是一方面的操作,像什么起码状态转换也是可以操作的.深搜就

最短路问题------分别用深搜和广搜去解题

最少步数 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 这有一个迷宫,有0~8行和0~8列: 1,1,1,1,1,1,1,1,1 1,0,0,1,0,0,1,0,1 1,0,0,1,1,0,0,0,1 1,0,1,0,1,1,0,1,1 1,0,0,0,0,1,0,0,1 1,1,0,1,0,1,0,0,1 1,1,0,1,0,1,0,0,1 1,1,0,1,0,0,0,0,1 1,1,1,1,1,1,1,1,1 0表示道路,1表示墙. 现在输入一个道路的坐标作为起点

深搜和广搜

先说说这个神秘的深搜: 前几天我心中的大牛给我讲了深搜感觉还是挺简单的,可大牛告诉我深搜深搜深的让你不知道怎么搜 我们也是从一道题来看:n的全排列 比如说3的全排列 123 213 321 这就是全排列   在没学过深搜的时候我们会用for循环来做这道题 但是如果n很大的时候就不行了 所以我们就一定要深搜了 其实在我看来深搜和递归是亲兄弟 深搜就是递归的加强版 我先写一个简单的dfs(深搜)函数的代码 #include<stdio.h> int dfs(int x) { if(x > n

深搜 ,广搜,队列 nyoj 27 水池数目

水池数目 时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地图上仅标识了此处是否是水池,现在,你的任务来了,请用计算机算出该地图中共有几个水池. 输入 第一行输入一个整数N,表示共有N组测试数据 每一组数据都是先输入该地图的行数m(0<m<100)与列数n(0<n<100),然后,输入接下来的m行每行输入n个数,表示此处有水还是没水(1表示此处是水

深搜与广搜

DFS(深度优先搜索) 从起点出发,朝任一个可能的方向走,走过的点要做标记,一直向前走.若走不了了,就回退一步,从这一个状态走向没有走过的另一个方向. 之所以称为深度优先搜索,因为它是朝着一个方向一直走到底,以深度优先,然后回溯. DFS一般用的是递归的方法. 迷宫问题 给一个迷宫,0表示道路,1表示墙壁,找出一条从左上角到右下角的最短路径 首先建立一个next[4][2]数组,表示下一步要走的方向,自定义方向的优先级,本题是从左上到右下, 那么,我可以按照下,右,上,左的顺序,则next[4]

算法学习笔记 二叉树和图遍历—深搜 DFS 与广搜 BFS

图的深搜与广搜 马上又要秋招了,赶紧复习下基础知识.这里复习下二叉树.图的深搜与广搜.从图的遍历说起,图的遍历方法有两种:深度优先遍历(Depth First Search), 广度优先遍历(Breadth First Search),其经典应用走迷宫.N皇后.二叉树遍历等.遍历即按某种顺序访问"图"中所有的节点,顺序分为: 深度优先(优先往深处走),用的数据结构是栈, 主要是递归实现: 广度优先(优先走最近的),用的数据结构是队列,主要是迭代实现: 对于深搜,由于递归往往可以方便的利

算法学习笔记(六) 二叉树和图遍历—深搜 DFS 与广搜 BFS

图的深搜与广搜 复习下二叉树.图的深搜与广搜. 从图的遍历说起.图的遍历方法有两种:深度优先遍历(Depth First Search), 广度优先遍历(Breadth First Search),其经典应用走迷宫.N皇后.二叉树遍历等.遍历即按某种顺序訪问"图"中全部的节点,顺序分为: 深度优先(优先往深处走),用的数据结构是栈, 主要是递归实现. 广度优先(优先走近期的).用的数据结构是队列.主要是迭代实现. 对于深搜.因为递归往往能够方便的利用系统栈,不须要自己维护栈.所以通常实