博客
关于我
Codeforces Round #617 (Div. 3) F. Berland Beauty(LCA+思维)
阅读量:387 次
发布时间:2019-03-05

本文共 648 字,大约阅读时间需要 2 分钟。

在这里插入图片描述

在这里插入图片描述
题意:给定一棵n个点的树以及n-1条边,现在给出m组ui,vi,wi,表示ui到vi这条最短路径上的最小边权是wi,要你构造出树的边权。
思路:树上两点的最小边权可以通过lca的方法来遍历求出,关键是怎么构造边权?其实可以把给出的m组条件按从大到小排序,只要保证i点和j点的路径上是权值最大的边先赋值就行。

#include
using namespace std;const int maxn=5e3+1;const int INF=1e6;int n,m,num[maxn],size[maxn],ans[maxn],father[maxn],deep[maxn];struct cxk{ int v,id;};struct node{ int u,v,w;}s[maxn];vector
g[maxn];bool cmp(const node &a,const node &b){ return a.w>b.w;}void dfs(int u,int fa){ father[u]=fa; deep[u]=deep[fa]+1; for(auto to:g[u]) { if(to.v==fa) continue; dfs(to.v,u); size[to.v]=to.id; } num[u]=INF;}bool check(int x,int y,int k){ int minn=INF; if(deep[x]

转载地址:http://woewz.baihongyu.com/

你可能感兴趣的文章
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 到底能不能放到 Docker 里跑?
查看>>
mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
查看>>
mysql 协议的退出命令包及解析
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
mysql 四种存储引擎
查看>>
MySQL 基础模块的面试题总结
查看>>
MySQL 备份 Xtrabackup
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>