当前位置: 首页 > 编程日记 > 正文

【洛谷P1697】货车运输

首先,对于所有从x能到达y的路径中,限重越大越好 

因此我们用Kruskal最大生成树得到一片森林(不一定都联通)

之后dfs维护森林的深度和LCA的预处理limit[x][0](x向上跳2^i步的边权最小值) 

对于每个询问,求x和y到lca的边权最小值即可

  1 #include<cstdio>
  2 #include<cstring>
  3 #include<algorithm>
  4 using namespace std;
  5 #define N 10010
  6 #define M 100010
  7 #define INF 100000000 
  8 struct fx{
  9     int to,w,from,next;
 10     
 11 }e[M],t[M];
 12 int size,n,m,q,head[M],maxl[N],father[N];
 13 int fa[N][25],limit[N][25],deep[N],vis[N];
 14 void uni(int x,int y,int z){
 15     size++;
 16     e[size].to=y;
 17     e[size].from=x;
 18     e[size].w=z;
 19 }
 20 void Uni(int x,int y,int z){
 21     size++;
 22     t[size].next=head[x];
 23     head[x]=size;
 24     t[size].to=y;
 25     t[size].from=x;
 26     t[size].w=z;
 27 }
 28 bool cmp(fx a,fx b){
 29     return a.w>b.w;
 30 }
 31 int find(int x){
 32     if (father[x]!=x) father[x]=find(father[x]);
 33     return father[x];
 34 }
 35 void swap(int &x,int &y){
 36     int tmp;
 37     tmp=x;
 38     x=y;
 39     y=tmp;
 40 }
 41 void kruskal(){
 42     int x,y,r1,r2,cnt;
 43     for (int i=1;i<=n;i++)
 44         father[i]=i;
 45     sort(e+1,e+m+1,cmp);
 46     size=0;cnt=n;
 47     for (int p=1;p<=m&&cnt>1;p++){
 48         x=e[p].from;
 49         y=e[p].to;
 50         r1=find(x);
 51         r2=find(y);
 52         if (r1!=r2){
 53             father[r1]=r2;
 54             cnt--;
 55             Uni(x,y,e[p].w);
 56             Uni(y,x,e[p].w);
 57         }
 58     }
 59 }
 60 void dfs(int x,int xx){
 61     vis[x]=1;
 62     fa[x][0]=xx;
 63     for (int k=head[x];k;k=t[k].next){
 64         int y=t[k].to;
 65         if (y==xx) continue;
 66         deep[y]=deep[x]+1;
 67         limit[y][0]=t[k].w;
 68         dfs(y,x);
 69     }
 70 }
 71 void Limit(){
 72     for (int j=1;j<=20;j++)
 73         for (int i=1;i<=n;i++){
 74             limit[i][j]=min(limit[fa[i][j-1]][j-1],limit[i][j-1]);
 75             fa[i][j]=fa[fa[i][j-1]][j-1];
 76         }
 77 }
 78 int LCA(int x,int y){
 79     int d,minl=INF;
 80     if (deep[x]<deep[y])
 81         swap(x,y);
 82     d=deep[x]-deep[y];
 83     for (int i=0;i<=20;i++)
 84         if ((1<<i)&d) {
 85             minl=min(minl,min(limit[x][i],limit[x][0]));
 86             x=fa[x][i];
 87         }
 88     if (x==y) return minl;//相等则不需向上跳   
 89     for (int i=20;i>=0;i--)
 90         if (fa[x][i]!=fa[y][i]){
 91             minl=min(minl,min(limit[x][i],limit[y][i]));
 92             x=fa[x][i];
 93             y=fa[y][i];
 94         }
 95     minl=min(minl,min(limit[x][0],limit[y][0]));
 96     return minl;
 97 }
 98 int main(){
 99     int x,y,z,r1,r2;
100     size=0;
101     scanf("%d %d",&n,&m);
102     for (int i=1;i<=m;i++){
103         scanf("%d %d %d",&x,&y,&z);
104         uni(x,y,z);
105     }
106     kruskal();
107     for (int i=1;i<=n;i++) 
108         if (!vis[i]){
109             deep[i]=1;
110             dfs(i,0);//森林  
111         }
112     Limit();
113     scanf("%d",&q);
114     for (int i=1;i<=q;i++){
115         scanf("%d %d",&x,&y);
116         r1=find(x);
117         r2=find(y);
118         if (r1!=r2) printf("-1\n");
119         else printf("%d\n",LCA(x,y));
120     }
121     return 0;
122 }
STD

转载于:https://www.cnblogs.com/Absolute-Zero/p/5947460.html

相关文章:

win7上Docker使用

1、启动docker&#xff1a; Docker Quickstart Terminal &#xff08;快捷键&#xff09;启动docker 2、SECURECRT工具链接docker&#xff1a; 转载于:https://www.cnblogs.com/aibaiyang/p/9007074.html

qt4的quick程序升级到qt5_最新8月书单出炉!送给你程序员

&#xff18;月好书赏不停&#xff0c;喜欢的就收藏一下。&#xff11;、计算广告&#xff1a;互联网商业变现的市场与技术&#xff08;第2版&#xff09;作者&#xff1a;刘鹏、王超全球第一本全面讲解计算广告与互联网变现秘密的专业图书升级版北冥乘海生 刘鹏老师力作&#…

都说区块链颠覆未来,区块链究竟能改变什么?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 区块链&#xff0c;有时像个天使&#xff0c;有时像个魔鬼。 有人说它是金融泡沫&#xff0c;说他是彻底的庞氏骗局&#xff1b;有人说它能改变世界…

python银行家算法代码_避免死锁的银行家算法C++程序实现

&#xfeff;&#xfeff;本篇博文为追忆以前写过的算法系列第二篇(20081021)温故知新目的&#xff1a;具有代表性的死锁避免算法是Dijskstra给出的银行家算法。本实验是基于银行家算法的思想通过编写C程序实现银行家算法的计算机程序化。使其更有用。同一时候也加深了有关自愿…

shell脚本编程学习笔记(四)shell操作数据库

一、数据库基本操作 1&#xff09;登录mysql服务器&#xff1a;mysql -u root -p 密码 2&#xff09;查看数据库&#xff1a;show databases 3&#xff09;查看表&#xff1a;show tales from db; 4&#xff09;查看表结构&#xff1a;desc table; 5&#xff09;创建表&#xf…

WebFrom模拟MVC

如&#xff1a; aspx前台 这样写生成页面时不会产生新的html标签&#xff0c;用控件则会产生新的html标签 <h1><% title %></h1> <p><% content %></p><ul> <% foreach (string item in list){%> <li>…

区块链的未来在哪里

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 经历了早期的野蛮成长之后&#xff0c;区块链行业的发展开始回归理性客观的发展阶段。探索区块链对于互联网行业的支持作用&#xff0c;而非颠覆作…

Spring注解之 @EnableScheduling计划任务注解

要实现计划任务&#xff0c;首先通过在配置类注解EnableScheduling来开启对计划任务的支持&#xff0c; 然后在要执行计划任务的方法上注解Scheduled&#xff0c;声明这是一个计划任务 示例&#xff1a;计划任务执行类 在这个类中的方法上需要Scheduled注解配合EnableSchedulin…

python爬虫案例_推荐上百个github上Python爬虫案例

现在学生都对爬虫感兴趣&#xff0c;这里发现一些好的github开源的代码&#xff0c;分享给各位1、awesome-spider 该网站提供了近上百个爬虫案例代码&#xff0c;这是ID为facert的一个知乎工程师开源的&#xff0c;star6000https://github.com/facert/awesome-spider​github.c…

二元一次方程组

二元一次方程组&#xff08;C语言&#xff09; 学生&#xff1a;缪晓敏&#xff0c;施嘉依 #include <stdio.h>#include <math.h>int main() {double a1,b1,c1,a2,b2,c2,d,e,f;printf("a1 b1 c1 : ");scanf("%lf %lf %lf",&a1,&b1,&am…

超级账本(Hyperledger Fabric)源码分析之一:总览

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 一、编译 1、环境准备 需要提前在linux或者mac机器上安装如下软件 1&#xff09;Go&#xff0c;注意设置好gopath&#xff08;笔者安装的是go1.8…

建模与设计01

转载于:https://www.cnblogs.com/invisible2/p/9016732.html

Bzoj2110--Wc2011Xor

考虑如果我们已经到达了终点&#xff0c;那么从终点出发显然可以异或上图中任何地方一个环的异或值后再回到终点&#xff0c;那么我们显然可以在到达终点后根据环的异或值调整自己 所以我们可以先处理出环上的异或值&#xff0c;我的做法是先做一颗生成树&#xff0c;然后dfs确…

usb打印机命令_Hyper-V与你的虚拟机共享设备、USB设备

仅适用于 Windows 虚拟机。增强会话模式可通过 RDP(远程桌面协议)将 Hyper-V 与虚拟机连接起来。 这不仅会改善你的整体虚拟机查看体验&#xff0c;而且使用 RDP 连接还可以使虚拟机与你的计算机共享设备。 由于 RDP 在 Windows 10 中默认打开&#xff0c;所以与 Windows 虚拟机…

以太坊源码分析之随心笔记

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 以太坊索引 table.go 定期随机选取一些节点找他们要他们的节点&#xff0c;放到本地&#xff0c;也就是一个随机找节点的table 里头的bucket 和 no…

ACM_求N^N的前5位数和后5位数(数论)

NNNNN Time Limit: 2000/1000ms (Java/Others) Problem Description: 对于整数N&#xff0c;求N^N的前5位和后5位&#xff08;1057题加强版) Input: 多组测试数据&#xff0c;每组测试数据输入为一个整数n&#xff08;6 < n < 10^9&#xff09;&#xff0c;n为0时结束。 …

ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml)

我们都知道在使用WebApi的时候Controller会自动将Action的返回值自动进行各种序列化处理&#xff08;序列化为json&#xff0c;xml等&#xff09;&#xff0c;但是如果Controller的自动序列化后的结果不是我们想要的该怎么办呢&#xff1f;其实在MVC中有一个GlobalConfiguratio…

ai为什么要栅格化_三大优势告诉你,为什么一定要加盟AI定制家居

随着90后、00后逐渐成为社会的主力&#xff0c;他们也进入到了住房和家居市场&#xff0c;成为消费的主力军。和以前的消费者不同&#xff0c;生活条件更为优越的他们有能力&#xff0c;有想法追求更好的生活和居住环境&#xff0c;于是定制家居市场在这样的市场条件下蓬勃发展…

当区块链遇到零知识证明

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 什么是零知识证明 零知识证明的官方定义是能够在不向验证者任何有用的信息的情况下&#xff0c;使验证者相信某个论断是正确的。这个定义有点抽象&a…

从条纹边框的实现谈盒子模型(转)

类似下面这个图形&#xff0c;只使用一个标签&#xff0c;可以有多少种实现方式&#xff1a; 假设我们的单标签为 div: 1<div></div>定义如下通用 CSS: 12345div{position:relative;width: 180px;height: 180px;}这一题主要考查的是盒子模型 Box Model 与 背景 bac…

python表格筛选打印_按行名进行表格筛选:awkpythonR

引入Excel确实很强大。用Excel查找一行很容易&#xff0c;同样的事情1000次就很复杂。批量查询的需求应运而生~实验狗确实需要各种帮助&#xff0c;不然就傻傻复制啦~1.awk读取多个文件awk BEGIN{OFSFS"\t"}ARGIND1{print $0, $1;}ARGIND2{} file1 file21)awk初步提取…

SVG和canvas

1、SVG实现的圆环旋转效果 参考&#xff1a;http://www.softwhy.com/article-6472-1.html 2、SVG中的图形可以通过 transform"matrix(0,-1,1,0,0,440)"进行旋转。 3、svg代码可以单独放在一个后缀名为 .svg 的文件中保存起来。这个文件就是矢量图片文件。 这点用来制…

用零知识证明解决投票安全

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 背景 我们经常会遇到需要给别人投票的情况&#xff0c;比如有些公司会组织员工给领导做反向打分&#xff0c;但是往往员工都不敢“真心实意”的打分…

gitLab创建自己的私有库

一.创建私有库的流程简介 创建一个项目,留着后面的流程3制作私有库在可以创建私有库的地方创建一个code repository, code repository是代码仓库,我们把代码上传到这个仓库。在可以创建私有库的地方创建一个spec repository, spec repository是配置仓库,所有的配置按照包名、版…

AngularJS安装配置与基础概要整理(上)

以前整理的&#xff0c;可供参考。 安装&#xff1a; 1.首先要安装node.js和它的npm包管理系统。&#xff08;nodejs相关待整理&#xff09; 2.安装grunt .grunt是一个基于任务的Javascript工程命令行构建工具。 在dos窗口输入&#xff1a;npm install grunt-cli -g 具体模块安…

通风与防排烟工程电子书_菠菜关于防排烟系统使用软接头工程量计算注意及定额选用建议...

前言&#xff1a;前几日分享《工程建设标准强制性条文》关于安装专业相关内容&#xff0c;其余规范部分&#xff0c;建议大家自行查看&#xff0c;不再继续分享。今日继续分享《建筑防烟排烟系统技术标准》相关内容依据1&#xff1a;2.1 设于排风兼排烟系统上的软接管必须为不燃…

超级账本(Hyperledger Fabric)之权限管理浅析

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 超级账本&#xff08;Hyperledger Fabric&#xff09;之权限管理浅析 超级账本是联盟链的代表&#xff0c;而其相对于共链&#xff08;例如比特币&a…

Java通过JDBC连接MySQL数据库

代码描述&#xff1a;把前台获取的字段作为查询条件&#xff0c;返回符合条件的记录。 1 package com.imooc.dao;2 3 import java.sql.Connection;4 import java.sql.DriverManager;5 import java.sql.PreparedStatement;6 import java.sql.ResultSet;7 import java.sql.SQLExc…

关于C#调用非托管DLL,报“内存已损坏的”坑,坑,坑

因客户需求&#xff0c;与第三方对接&#xff0c;调用非托管DLL&#xff0c;之前正常对接的程序&#xff0c;却总是报“内存已损坏的异常”&#xff0c;程序进程直接死掉&#xff0c;折腾到这个点&#xff08;2018-05-11 00:26&#xff09;&#xff0c;终于尘埃落定,直接上程序…

python会不会出现内存泄露_Python内存泄漏和内存溢出的解决方案

一、内存泄漏像Java程序一样&#xff0c;虽然Python本身也有垃圾回收的功能&#xff0c;但是同样也会产生内存泄漏的问题。对于一个用 python 实现的&#xff0c;长期运行的后台服务进程来说&#xff0c;如果内存持续增长&#xff0c;那么很可能是有了“内存泄露”。1、内存泄露…