Computer

 
链接:
http://acm.hdu.edu.cn/showproblem.php?pid=2196
https://blog.csdn.net/shuangde800/article/details/9732825


#include<iostream> #include<cstdio> #include<algorithm> #include<vector> #include<queue> #include<cmath> #include<cstring> using namespace std; typedef long long int64; const int INF = 0x3f3f3f3f; const double PI = acos(-1.0); const int MAXN = 10010; struct Node { int v, w; }; vector<Node>adj[MAXN]; int indeg[MAXN]; int val[MAXN]; int n, m; int64 f[MAXN][2]; int vis[MAXN]; int64 dfs1(int u) //从自己开始 {vis[u]=true; //标记自己f[u][0] = 0; //自己到原点的距离初始化0;for(int i=0;i<adj[u].size();++i)//自己到每个点的距离取最大值 {int v = adj[u][i].v; //节点int w = adj[u][i].w; //到节点的权值if(vis[v]) //被标记跳过continue;f[u][0]=max(f[u][0],dfs1(v)+w);//自己到原点的最大距离=自己到原点的距离节点到自己的距离加上自己到谁大 }return f[u][0];//返回节点到自己的距离 } void dfs2(int u, int fa_w) {vis[u] = true;//标记自己int max1=0, v1, max2=0, v2; //初始化for(int i=0; i<adj[u].size(); ++i){int v=adj[u][i].v; //节点int w=adj[u][i].w; //到节点的权值if(vis[v])continue; //被标记跳过int tmp=f[v][0]+w; //距离为目标节点到叶子加上自己到节点的权值。if(tmp>max1) //(第一次t)如果下一个子节点距离更长 {max2=max1; //(第一次为0)赋上次值v2=v1; //(第一次。。) 为次节点max1=tmp; //(第一次为目标节点到叶子加上自己到节点的权值。)v1=v; //(第一次为目标权值) }else if(tmp==max1||tmp>max2) //如果与次值相等或者比次值大 {max2=tmp;//次值等于这个值 。v2=v;//次值节点为次节点。 }}if(u!= 1) //如果不为根节点 {int tmp = f[u][1];//除去子节点最长距离的子节点最长距离int v = -1;//目标节点为-1;if(tmp > max1){max2=max1;v2=v1;max1=tmp;v1=v;}else if(tmp==max1||tmp>max2){max2=tmp;v2=v;}}for(int i=0; i<adj[u].size(); ++i){int v=adj[u][i].v;int w=adj[u][i].w;if(vis[v])continue;if(v==v1){f[v][1] = max2 + w;}else{f[v][1] = max1 + w;}dfs2(v, w);} } int main() {while(~scanf("%d", &n) && n){for(int i=1;i<=n;++i)adj[i].clear();for(int u=2;u<=n;++u){int v,w;scanf("%d%d", &v, &w);adj[u].push_back((Node){v,w}); //装入目标节点,权值adj[v].push_back((Node){u,w}); //装入自己,权值 }memset(f, 0, sizeof(f));memset(vis, 0, sizeof(vis));dfs1(1);memset(vis, 0, sizeof(vis));dfs2(1, 0);for(int i=1; i<=n; ++i){cout<<max(f[i][0],f[i][1])<<endl;} } return 0; }

 

转载于:https://www.cnblogs.com/JCRL/p/10072376.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/281386.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

智慧“昆明”在路上 未来充满精彩

智慧城市是运用物联网、云计算、大数据、移动互联网、空间地理信息集成等新一代信息技术&#xff0c;促进城市规划、建设、管理和服务智慧化的新理念和新模式。近年来&#xff0c;昆明市全面加快智慧城市建设&#xff0c;力争通过三年的努力&#xff0c;打造区域信息辐射中心的…

《精读 Mastering ABP Framework》教程发布

精读《Mastering ABP Framework》学习总结&#xff0c;掌握软件开发最佳实践&#xff0c;构建可维护 .NET 解决方案。从 ABP Framework 框架中学习如何构建现代 WEB 应用程序。掌握 ABP Framework 框架ABP Framework 是一个完整的基础架构&#xff0c;遵循软件开发最佳实践&…

C# 委托知识总结

1.什么是委托&#xff0c;为什么要使用委托 我正在埋头苦写程序&#xff0c;突然想喝水&#xff0c;但是又不想自己去掉杯水而打断自己的思路&#xff0c;于是我就想让女朋友去给我倒水。她去给我倒水&#xff0c;首先我得让她知道我想让她干什么&#xff0c;通知她之后我可以继…

阿里云大学课程学习有奖征文活动现在开始

2019独角兽企业重金招聘Python工程师标准>>> "学有所获&#xff0c;分享为美"--阿里云大学课程学习有奖征文活动开始啦~~ 看课程&#xff0c;写心得&#xff0c;赢千元大奖&#xff0c;还有机会加入阿里云大学技术作者群&#xff01;想试试自己的技术文笔…

配置网络测试环境的批处理

引言 有次需要测试 50 台左右的设备&#xff0c;每个都要连上电脑并搭好测试环境。这种事当然用服务器下发配置最方便&#xff0c;但条件不允许哦&#xff0c;只得手工一台台设。 写了个批处理配置脚本&#xff0c;放到 U 盘上&#xff0c;最好再配上 autorun.inf&#xff0c;嘿…

Android 的系统架构

Android 的系统架构和其它操作系统一样&#xff0c;采用了分层的架构。android 分为四个层&#xff0c;从高层到低层分别是应用程序层、应用程序框架层、系统运行库层和 linux 核心层。 Android 是以 Linux 为核心的手机操作平台&#xff0c;作为一款开放式的操作系统&#xf…

记一次 .NET 某制造业 MES 系统崩溃分析

一&#xff1a;背景 1.讲故事前段时间有位朋友微信找到我&#xff0c;说他的程序偶尔会出现内存溢出崩溃&#xff0c;让我帮忙看下是怎么回事&#xff0c;咨询了下程序是 x86 部署&#xff0c;听到这个词其实心里已经有了数&#xff0c;不管怎么样还是用 windbg 分析一下。二&a…

HTTPS协议开通,Apache服务器CSR签名申请

登录您的服务器终端 (SSH)。在命令提示符下&#xff0c;键入以下命令&#xff1a;openssl req -new -newkey rsa:2048 -nodes -keyout yourdomain.key -out yourdomain.csr将 yourdomain 替换为您要保护的域名。例如&#xff0c;如果您的域名是 coolexample.com&#xff0c;您就…

首次公开!单日600PB的计算力--阿里巴巴EB级大数据平台的进击

摘要&#xff1a; 每年的双11之前&#xff0c;也是MaxCompute各种乾坤大挪移落定的时候&#xff0c;因为双11就是各种大折腾项目的自然deadline。在今年双11之前&#xff0c;一路向北迁移和在离线混部项目&#xff0c;将杭州集群除蚂蚁外整体迁移到张北&#xff0c;涉及了绝大部…

软件测试金字塔

软件测试金字塔 在敏捷方法中&#xff0c;持续集成是其基石&#xff0c;持续集成的核心是自动化测试。下面这篇关于测试金字塔的文章&#xff0c;来自大师Martin Fowler。 测试金字塔的概念来自Mike Cohn&#xff0c;在他的书Succeeding With Agile中有详细描述&#xff1a;测试…

使用pm2守护你的.NET Core应用程序

简介PM2是常用的node进程管理工具&#xff0c;它可以提供node.js应用管理&#xff0c;如自动重载、性能监控、负载均衡等。同类工具有Supervisor、Forever等。pm2是一个进程管理工具,可以用它来管理你的node进程&#xff0c;并查看node进程的状态&#xff0c;当然也支持性能监控…

C-指针02 2017/11/24

/* 复习 1.指针类型 int *指针类型 指针指向的变量类型指针指向哪个变量2.基本数据类型 4种指针类型 存放的地址 和系统有关系 4个字节数组类型结构体 枚举 联合3.指针加法减法 p 和数组搭配使用4.两个运算符 *取值(解引用) &取地址5. *(pi) p[i] …

程序员搞笑段子

转载于:https://www.cnblogs.com/Zhusi/p/10083474.html

学习之旅——工作记录日志2017.7.09

1.例子&#xff1a;在dev_lala上开发完毕后&#xff0c;切换到dev分支&#xff0c;在此分支上pull最新的代码来保证dev上的代码是最新的。在dev分支上git branch -b haha一个新的分支haha&#xff0c; 用git log dev_lala查看提交记录&#xff0c;将我自己的几个记录加到haha分…

Git常用命令与基本操作

Git操作指令系统配置基本命令获取/删除Git仓库更新记录撤销操作远程仓库的使用分支系统系统配置 git config 为系统自带的配置指令&#xff0c;它可以控制GIT的行为和外观 配置用户信息 git config --global user.name "John Doe" git config --global user.email …

CA周记 - 在 Azure ML 上用 .NET 跑机器学习

.NET 是一个跨平台&#xff0c;全场景应用的开源技术。你有在用 .NET 做机器学习/深度学习的应用吗&#xff1f;如果从框架角度&#xff0c;ML.NET / Tensorflow.NET / 不断在进步的 TorchSharp 通过几年的发展已经开始稳定&#xff0c;但如果在一些大型项目上&#xff0c;特别…

iOS10 优化APP首次安装网络权限提示方案

我刚经历了一场末日&#xff08;停电&#xff09;&#xff0c;特别是在你想写文档的时候。。。 言归正传&#xff0c;今天的问题是解决iOS10系统下首次按钮APP弹出的网络权限提示所带来了问题以及优化。 起因 查了相关文章知道由于大陆工信部出台的新规指出&#xff0c;应用在未…

su命令

从一个用户切换到另一个用户&#xff1a;su - ceshi(ceshi是用户名) 查看当前用户&#xff1a;whoami 在不切换用户的情况执行另一个用户的命令&#xff1a;例&#xff1a;su - -c "touch /tmp/111.txt" admin 若用户没有加目录需要添加家目录&#xff0c;并更改所有…

C语言基础知识【数据类型】

C 数据类型1.在 C 语言中&#xff0c;数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间&#xff0c;以及如何解释存储的位模式。2.C 中的类型可分为以下几种&#xff1a;序号 类型与描述1 基本类型&#xff1a;它们是算…

PS批量替换内容

在制作图片物料的时候&#xff0c;有时会碰到需要制作大量内容格式一致&#xff0c;但部分文字或图片不同的图片&#xff0c;这里我们使用PS的变量功能 物料准备&#xff1a;准备好需要替换的图片和文字&#xff0c;使用excel制作出需要替换的内容&#xff0c;第一行name和pic…