博客
关于我
zoj 3195 Design the city LCA Tarjan
阅读量:443 次
发布时间:2019-03-06

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

题目大意:

求三点之间的最短距离

思路:

有了两点之间的最短距离求法,不难得出:

对于三个点我们两两之间求最短距离 得到 d1 d2 d3
那么最短距离就是 d = ( d1 + d2 + d3 ) / 2

  • 要注意每个数组的范围大小,因为这个问题手抖敲错,TLE+RE一整页/(ㄒoㄒ)/~~
  • 用前向星来保存边和询问,空间卡的也很严
  • 如下图所示:所求路线为紫色,等于蓝色+黄色+绿色之和的一半

代码:

#include 
using namespace std;const int maxn = 50005;const int maxm = 70005;struct node1 { int next,to,w;} e[maxn*2];struct node2 { int next,to,id;} q[maxm*6];int n,m,head1[maxn],head2[maxn],cnt1,cnt2,vis[maxn],f[maxn],res[maxm*6],dist[maxn];inline void add1(int u, int v, int w) { e[cnt1].to=v; e[cnt1].w=w; e[cnt1].next=head1[u]; head1[u]=cnt1++;}inline void add2(int u, int v, int id) { q[cnt2].to=v; q[cnt2].id=id; q[cnt2].next=head2[u]; head2[u]=cnt2++;}inline void init() { cnt1=cnt2=0; memset(head1,-1,sizeof(head1)); memset(head2,-1,sizeof(head2)); memset(vis,0,sizeof(vis));}inline int Find(int x) { return x == f[x] ? x : f[x] = Find(f[x]);}inline void tarjan(int s) { vis[s]=1; f[s]=s; int t; for(int i=head1[s]; i!=-1; i=e[i].next) { if(!vis[t=e[i].to]) { dist[t]=dist[s]+e[i].w; tarjan(t); f[t]=s; } } for(int i=head2[s]; i!=-1; i=q[i].next) if(vis[t=q[i].to]) res[q[i].id]=dist[s]+dist[t]-2*dist[Find(t)];}int main() { int cnt=0,u,v,w,x,y,z; while(~scanf("%d",&n)) { init(); for(int i=1; i

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

你可能感兴趣的文章
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>
mysql加强(6)~子查询简单介绍、子查询分类
查看>>
mysql加强(7)~事务、事务并发、解决事务并发的方法
查看>>
MySQL千万级多表关联SQL语句调优
查看>>
mysql千万级大数据SQL查询优化
查看>>
MySQL千万级大表优化策略
查看>>