题目:http://115.28.138.223/view.page?gpid=T24

题意就是让求树上的任意两个节点间的距离的最大值。就是树的直径。

首先树的直径模板转载自http://www.07net01.com/2015/08/908766.html

模板思路是先任意确定一个点a,加入到队列当中。然后对这个点用广搜找到和它距离最远的点b。然后用相同的方法对点b找距离它最远的点。这个距离就是要求的直径。

实现:因为求树的直径题目数据量往往比较大,所以用邻接表来储存数据;至于对两个端点的查找通过bfs实现,先将第一次选择的起点a队。 然后开始搜索与a连接的所有边,并将权值存入dis[]数组 dis[x]=dis[top]+edge[i].w(dis[x]指的是当前搜索到的点 与之前与它相连的搜索过边的总权值,dis[top]是指当前搜索到的点的之前与它相连的搜索过边的总权值,edge[i].w是点top到当前搜索到的点 的连线的权值)完成于对当前点的搜索后,将其入队,然后对下 一个点进行此操作,每次搜索时,同时将最大的权值存入sum中如此重复直至队列为空,这样这个搜素结束后,sum的值就是a点到距离其最远的点b的总权值之和;此时再以b为起点进行第二次搜索(第 二次搜 索步骤与第一次相同)

其实就是简单的邻接表应用。只是在下不太熟。于是,觉得很机智。。。。。

#include<stdio.h>
#include<iostream>
#include<string.h>
#define maxn 10010
using namespace std; int head[maxn*];
int vis[maxn*]; // 判断每个节点是否已经被访问过。
int dis[maxn*]; //存储每个节点到当前节点的路径长
int que[maxn*];
int edgeNum;
int n, m;
int ans;
int sum; struct Edge {
int v, c, nxt;
}edge[maxn*]; // T_T哭晕...居然三倍的会TLE...TLE... void addEdge(int a, int b, int c) {
edge[edgeNum].v = b;
edge[edgeNum].c = c;
edge[edgeNum].nxt = head[a];
head[a] = edgeNum++;
} void getMap() {
edgeNum = ;
memset(head, -, sizeof(head));
for (int i=; i<=n; ++i) {
int temp;
scanf("%d", &temp);
addEdge(temp, i, );
addEdge(i, temp, );
}
for (int i=; i<=m; ++i) {
int temp;
scanf("%d", &temp);
addEdge(temp, i+n, );
addEdge(i+n, temp, );
}
} void bfs(int num) {
memset(vis, , sizeof(vis));
memset(dis, , sizeof(dis));
ans = num;
sum = ;
int front = -, rear = ;
que[++front] = num;
while(front >= rear) {
int top = que[front--];
for (int i=head[top]; i!=-; i=edge[i].nxt) {
int v = edge[i].v;
if (!vis[v]) {
dis[v] = dis[top] + edge[i].c;
vis[v] = ;
que[++front] = v;
if (sum < dis[v]) {
sum = dis[v];
ans = v;
}
}
}
}
} int main() {
while(~scanf("%d%d", &n, &m)) {
getMap();
bfs();
bfs(ans);
printf("%d\n", sum);
}
return ;
}

还有某大神做的一种,转载自:http://www.cnblogs.com/hate13/p/4643573.html

用DP。求出每个点的和所有点之间的距离的最大值和第二大值。然后它们的和的最大值就是树的直径。

初始化父亲节点的两个距离都是0。然后如果子节点最大值+1大于父亲节点的最大值。更新父亲节点的两个值。否则如果子节点最大值+1大于父亲节点的第二大值。那么只更新第二大值就可以了。

更机智。有木有。。(⊙o⊙)…额。。还是在下水平低。。

#include<stdio.h>
#include<iostream>
#include<string.h>
#define maxn 10010
using namespace std; int head[maxn*];
int n, m;
int dp[maxn*][];
int edgeNum; struct Edge {
int v,nxt;
}edge[maxn*]; // T_T哭晕...居然三倍的会TLE...TLE... void addEdge(int a, int b) {
edge[edgeNum].v = b;
edge[edgeNum].nxt = head[a];
head[a] = edgeNum++;
} void getMap() {
edgeNum = ;
memset(head, -, sizeof(head));
for (int i=; i<=n; ++i) {
int temp;
scanf("%d", &temp);
addEdge(temp, i);
//addEdge(i, temp, 1);
}
for (int i=; i<=m; ++i) {
int temp;
scanf("%d", &temp);
addEdge(temp, i+n);
//addEdge(i+n, temp, 1);
}
} void dfs(int u) {
dp[u][] = dp[u][] = ;
for (int i=head[u]; i!=-; i=edge[i].nxt) {
int v = edge[i].v;
dfs(v);
if (dp[v][]+ >= dp[u][]) {
dp[u][] = dp[u][];
dp[u][] = dp[v][]+;
}
else if (dp[v][]+ > dp[u][]) {
dp[u][] = dp[v][]+;
}
}
} int main() {
while(~scanf("%d%d", &n, &m)) {
getMap();
dfs();
int sum = ;
for (int i=; i<=n+m; ++i) {
int temp = dp[i][] + dp[i][];
sum = max(temp, sum);
}
printf("%d\n", sum);
}
return ;
}

CCF 2015-03-4 网络延时的更多相关文章

  1. CCF真题之网络延时

    201503-4 问题描述 给定一个公司的网络,由n台交换机和m台终端电脑组成,交换机与交换机.交换机与电脑之间使用网络连接.交换机按层级设置,编号为1的交换机为根交换机,层级为1.其他的交换机都连接 ...

  2. CCF CSP 201503-4 网络延时

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201503-4 网络延时 问题描述 给定一个公司的网络,由n台交换机和m台终端电脑组成,交换机 ...

  3. [ccf 4] 网络延时

    网络延时 问题描述 给定一个公司的网络,由n台交换机和m台终端电脑组成,交换机与交换机.交换机与电脑之间使用网络连接.交换机按层级设置,编号为1的交换机为根交换机,层级为      1.他的交换机都连 ...

  4. 2015年p2p网络借贷平台的发展现状

    2015年春暖花开,莺飞草长,股市大涨大跌起起落落,P2P网络借贷收到越来越多的人关注,P2P网络借贷平台是p2p借贷与网络借贷相结合的金 融服务网站,这么多P2P网络借贷平台排我们应该如何选择呢?小 ...

  5. iOS 学习笔记 六 (2015.03.28)常见错误

    2015.03.28 1. property's synthesized getter follows Cocoa naming convention for returning 'owned' ob ...

  6. Contest2071 - 湖南多校对抗赛(2015.03.28)

    Contest2071 - 湖南多校对抗赛(2015.03.28) 本次比赛试题由湖南大学ACM校队原创 http://acm.csu.edu.cn/OnlineJudge/contest.php?c ...

  7. CCF CSP 201709-4 通信网络

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201709-4 通信网络 问题描述 某国的军队由N个部门组成,为了提高安全性,部门之间建立了M ...

  8. CCF CSP 201403-4 无线网络

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201403-4 无线网络 问题描述 目前在一个很大的平面房间里有 n 个无线路由器,每个无线路 ...

  9. TCP协议之网络延时

    影响TCP 网络时延的因素硬件速度网络和服务器的负载请求和响应报文的尺寸客户端和服务器之间的距离TCP 协议的技术复杂性TCP协议产生的时延TCP 连接建立握手:TCP 慢启动拥塞控制:数据聚集的 N ...

随机推荐

  1. 20145335郝昊《网络攻防》Exp4 Adobe阅读器漏洞攻击

    20145335郝昊<网络攻防>Exp4 Adobe阅读器漏洞攻击 实验内容 初步掌握平台matesploit的使用 有了初步完成渗透操作的思路 本次攻击对象为:windows xp sp ...

  2. np.random.normal()正态分布

    高斯分布的概率密度函数 numpy中 numpy.random.normal(loc=0.0, scale=1.0, size=None) 参数的意义为: loc:float 概率分布的均值,对应着整 ...

  3. 同步TreeView中父结点和子结点的状态[以及Treeview的bug]

    此代码仅仅是二级结点,即父结点下面只有一层子结点,只有两层结构 /// <summary> /// 某个结点的CheckBox被选中 /// </summary> /// &l ...

  4. C# String.Join 与 StringBuilder 对比,谁更快

    String.Join 文档      StringBuilder 文档 这两天刷 Leedcode 做到一道 String 的题时突然想到这俩对比的问题,于是查了一下资料并简单对比了一下. 首先对于 ...

  5. HDU 2874 Connections between cities(LCA离线算法实现)

    http://acm.hdu.edu.cn/showproblem.php?pid=2874 题意: 求两个城市之间的距离. 思路: LCA题,注意原图可能不连通. 如果不了解离线算法的话,可以看我之 ...

  6. marquee 跑马灯公告

    1.原始 marquee 2.自定义 marquee .tops { color: #fff; height: 23px; margin: 0 0 0 20px; min-height: 23px; ...

  7. Android JNI学习(三)——Java与Native相互调用

    本系列文章如下: Android JNI(一)——NDK与JNI基础 Android JNI学习(二)——实战JNI之“hello world” Android JNI学习(三)——Java与Nati ...

  8. 使用CMake在Linux下编译tinyxml静态库

    环境:CentOS6.6+tinyxml_2_6_21.下载并解压tinyxml_2_6_2.zip unzip tinyxml_2_6_2.zip 2.在tinyxml文件夹里创建一个CMakeLi ...

  9. resin中关于url rewrite来传递jsessionid的问题

    最近两天在项目中碰到,一个很奇怪的问题.同一个账号多次切换登录时,会出现这个账号的信息在session中找不到,虽然可以登录成功,但是之后这个用户信息好像没有保存到session中一样,或者是被改变了 ...

  10. LeetCode--111--最长公共前缀

    问题描述: 给定一个二叉树,找出其最小深度. 最小深度是从根节点到最近叶子节点的最短路径上的节点数量. 说明: 叶子节点是指没有子节点的节点. 示例: 给定二叉树 [3,9,20,null,null, ...