HDU 4707 Pet(DFS(深度优先搜索)+BFS(广度优先搜索))
Pet
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 535 Accepted Submission(s): 258
10 2
0 1
0 2
0 3
1 4
1 5
2 6
3 7
4 8
6 9
DFS(深度优先搜索)
import java.io.*;
import java.util.*;
public class Main {
BufferedReader bu;
PrintWriter pw;
int MAX=1000001;
int t,n,d,e,num; int head[]=new int[MAX];
Node node[]=new Node[MAX];
boolean boo[]=new boolean[MAX]; public static void main(String[] args) throws Exception{
new Main().work();
}
void work()throws Exception{
bu=new BufferedReader(new InputStreamReader(System.in));
pw=new PrintWriter(new OutputStreamWriter(System.out),true); t=Integer.parseInt(bu.readLine());
while(t--!=0){
String str[]; str=bu.readLine().split(" ");
n=Integer.parseInt(str[0]);
d=Integer.parseInt(str[1]);
e=0;
num=1;
Arrays.fill(head, -1);
Arrays.fill(boo,false); for(int i=1;i<n;i++){
str=bu.readLine().split(" ");
int a=Integer.parseInt(str[0]);
int b=Integer.parseInt(str[1]); add(a,b);
add(b,a);
}
boo[0]=true;
DFS(0,0);
pw.println(n-num);
}
} void DFS(int x,int index){
if(index>=d)
return;
for(int i=head[x];i!=-1;i=node[i].next){
int v=node[i].v;
if(!boo[v]){
boo[v]=true;
num++;
DFS(v,index+1);
}
}
} void add(int a,int b){
node[e]=new Node();
node[e].v=b;
node[e].next=head[a];
head[a]=e++;
} class Node{
int v;
int next;
}
}
BFS(广度优先搜索)
import java.io.*;
import java.util.*;
public class Main {
BufferedReader bu;
PrintWriter pw;
Queue<Integer> que;
int MAX=200010;
int t,n,d,e,num; int[] head=new int[MAX];
boolean[] boo=new boolean[MAX];
Node[] node=new Node[MAX];
int dis[]=new int[MAX];
public static void main(String[] args) throws Exception{
new Main().work();
}
void work()throws Exception{
bu=new BufferedReader(new InputStreamReader(System.in));
pw=new PrintWriter(new OutputStreamWriter(System.out),true);
que=new LinkedList<Integer>();
t=Integer.parseInt(bu.readLine());
String str[];
while(t--!=0){
str=bu.readLine().split(" ");
n=Integer.parseInt(str[0]);
d=Integer.parseInt(str[1]); Arrays.fill(head,-1);
Arrays.fill(boo, false);
Arrays.fill(dis,0);
que.clear(); e=0;
num=0; for(int i=1;i<n;i++){
str=bu.readLine().split(" ");
int a=Integer.parseInt(str[0]);
int b=Integer.parseInt(str[1]);
add(a,b);
add(b,a);
}
boo[0]=true;
que.add(0);
BFS();
pw.println(num);
}
}
void BFS(){
while(!que.isEmpty()){
int t=que.poll();
for(int i=head[t];i!=-1;i=node[i].next){
int u=node[i].v;
if(!boo[u]){
dis[u]=dis[t]+1;
boo[u]=true;
que.add(u);
}
}
}
for(int i=0;i<n;i++){
if(dis[i]>d&&boo[i])
num++;
}
}
void add(int a,int b){
node[e]=new Node();
node[e].v=b;
node[e].next=head[a];
head[a]=e++;
}
class Node{
int v;
int next;
}
}
HDU 4707 Pet(DFS(深度优先搜索)+BFS(广度优先搜索))的更多相关文章
- DFS_BFS(深度优先搜索 和 广度优先搜索)
package com.rao.graph; import java.util.LinkedList; /** * @author Srao * @className BFS_DFS * @date ...
- 0算法基础学算法 搜索篇第二讲 BFS广度优先搜索的思想
dfs前置知识: 递归链接:0基础算法基础学算法 第六弹 递归 - 球君 - 博客园 (cnblogs.com) dfs深度优先搜索:0基础学算法 搜索篇第一讲 深度优先搜索 - 球君 - 博客园 ( ...
- BFS广度优先搜索 poj1915
Knight Moves Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 25909 Accepted: 12244 Descri ...
- 图的遍历BFS广度优先搜索
图的遍历BFS广度优先搜索 1. 简介 BFS(Breadth First Search,广度优先搜索,又名宽度优先搜索),与深度优先算法在一个结点"死磕到底"的思维不同,广度优先 ...
- 算法竞赛——BFS广度优先搜索
BFS 广度优先搜索:一层一层的搜索(类似于树的层次遍历) BFS基本框架 基本步骤: 初始状态(起点)加到队列里 while(队列不为空) 队头弹出 扩展队头元素(邻接节点入队) 最后队为空,结束 ...
- DFS+BFS(广度优先搜索弥补深度优先搜索遍历漏洞求合格条件总数)--09--DFS+BFS--蓝桥杯剪邮票
题目描述 如下图, 有12张连在一起的12生肖的邮票.现在你要从中剪下5张来,要求必须是连着的.(仅仅连接一个角不算相连) 比如,下面两张图中,粉红色所示部分就是合格的剪取. 请你计算,一共有多少 ...
- 深度优先dfs与广度bfs优先搜索总结+例题
DFS(Deep First Search)深度优先搜索 深度优先遍历(dfs)是对一个连通图进行遍历的算法.它的思想是从一个顶点开始,沿着一条路一直走到底,如果发现不能到达目标解,那就返回到上一个节 ...
- 步步为营(十六)搜索(二)BFS 广度优先搜索
上一篇讲了DFS,那么与之相应的就是BFS.也就是 宽度优先遍历,又称广度优先搜索算法. 首先,让我们回顾一下什么是"深度": 更学术点的说法,能够看做"单位距离下,离起 ...
- 【js数据结构】图的深度优先搜索与广度优先搜索
图类的构建 function Graph(v) {this.vertices = v;this.edges = 0;this.adj = []; for (var i = 0; i < this ...
随机推荐
- 使用Maven构建和部署J2EE应用程序的EAR文件
这篇文章.主要是技术上的整理,用来mark一下,用的时候參考. 一.新建项目 新建一个空的Maven Project项目 二.放入依赖 注:ear部署时假设里面有entity,会错误发生.所以不要把e ...
- [置顶] HMM Tutorial 隐马尔科夫模型
有一个月没有写博客了,这一个月系统的学习了HMM model. 上周周五做了个report 感觉还好. 所以把Slide贴上来.
- android的animator
3.0 以前,android支持两种动画模式,tween animation,frame animation,在android3.0中又引入了一个新的动画系统:property animation,这 ...
- 基于visual Studio2013解决C语言竞赛题之1002字符打印
题目 解决代码及点评 /************************************************************************/ /* ...
- hdu 2896 病毒侵袭 AC自动机 基础题
病毒侵袭 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- Java Arrays Tutorial (3)
Java Arrays Tutorial (3) Data types have a specific set of values. A byte cannot hold a value larger ...
- [置顶] CopyU!v2插件合集 [2013年7月18日更新]
这里提供了所有可供CopyU!v2使用的功能插件,您可以根据自己的需要下载安装使用,需要提醒您的是,安装过多的插件会影响CopyU!的运行性能,请合理的安装使用! 1.打包插件 版本:1.0.12.1 ...
- ios9怎么设置6位密码 ios9设置6位密码图文教程
在原来的 iOS 系统中,只有四位数字密码与复杂密码之分,而在 iOS9 系统中却多出了一个六位数字密码,那ios9怎么设置6位密码,今天小编就为大家带来ios9设置6位密码图文教程 在原来的 i ...
- C++中实现 time_t, tm 相互转换
time_t -> tm: localtime tm -> time_t: mktime time_t curTime; time(&curTime); dwCurTime = c ...
- perl json模块
JSON - JSON (JavaScript Object Notation) encoder/decoder 简介: use JSON; # imports encode_json, decode ...