233333想简单了。。。。

题解参见http://hzwer.com/3710.html

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxv 4050
#define maxe 200500
#define inf 0x7f7f7f7f7f7f7f7fLL
using namespace std;
struct edge
{
long long u,v,w,flag,nxt;
}e[maxe];
long long n,m,x,y,a,b,g[maxv],nume=,dis[maxv];
long long top[maxv],fath[maxv],dfn[maxv],dep[maxv],size[maxv],son[maxv],times=;
long long root,tot=,ls[maxv<<],rs[maxv<<],lazy[maxv<<];
void addedge(long long u,long long v,long long w,long long flag)
{
e[++nume].u=u;
e[nume].v=v;
e[nume].w=w;
e[nume].flag=flag;
e[nume].nxt=g[u];
g[u]=nume;
}
void dfs1(long long x)
{
size[x]=;son[x]=;
for (long long i=g[x];i;i=e[i].nxt)
{
long long v=e[i].v;
if ((e[i].flag) && (v!=fath[x]))
{
fath[v]=x;dep[v]=dep[x]+;dis[v]=dis[x]+e[i].w;
dfs1(v);
size[x]+=size[v];
if (size[v]>size[son[x]]) son[x]=v;
}
}
}
void dfs2(long long x,long long father)
{
dfn[x]=++times;top[x]=father;
if (son[x]) dfs2(son[x],father);
for (long long i=g[x];i;i=e[i].nxt)
{
long long v=e[i].v;
if ((e[i].flag) && (v!=fath[x]) && (v!=son[x]))
dfs2(v,v);
}
}
void build(long long &now,long long left,long long right)
{
now=++tot;lazy[now]=inf;
if (left==right) return;
long long mid=(left+right)>>;
build(ls[now],left,mid);
build(rs[now],mid+,right);
}
void modify(long long now,long long left,long long right,long long l,long long r,long long x)
{
if ((left==l) && (right==r))
{
lazy[now]=min(lazy[now],x);
return;
}
long long mid=(left+right)>>;
if (r<=mid) modify(ls[now],left,mid,l,r,x);
else if (l>=mid+) modify(rs[now],mid+,right,l,r,x);
else {modify(ls[now],left,mid,l,mid,x);modify(rs[now],mid+,right,mid+,r,x);}
}
long long lca(long long u,long long v)
{
long long f1=top[u],f2=top[v];
while (f1!=f2)
{
if (dep[f1]<dep[f2]) {swap(f1,f2);swap(u,v);}
u=fath[f1];f1=top[u];
}
if (dep[u]<dep[v]) return u;
else return v;
}
void work(long long x)
{
long long u=e[x].u,v=e[x].v,ret=dis[u]+e[x].w+dis[v];
long long t=lca(u,v);
if (t==v) return;
u=t;
long long f1=top[u],f2=top[v];
while (f1!=f2)
{
if (dep[f1]<dep[f2]) {swap(f1,f2);swap(u,v);}
modify(root,,n,dfn[f1],dfn[u],ret);
u=fath[f1];f1=top[u];
}
if (u!=v)
{
if (dep[u]>dep[v]) swap(u,v);
modify(root,,n,dfn[u]+,dfn[v],ret);
}
}
long long ask(long long now,long long left,long long right,long long pos)
{
if (left==right)
return lazy[now];
long long mid=(left+right)>>;
if (pos<=mid) return min(ask(ls[now],left,mid,pos),lazy[now]);
else return min(ask(rs[now],mid+,right,pos),lazy[now]);
}
int main()
{
scanf("%lld%lld",&n,&m);
for (long long i=;i<=m;i++)
{
scanf("%lld%lld%lld%lld",&x,&y,&a,&b);
addedge(x,y,a,b);
addedge(y,x,a,b);
}
dfs1();
dfs2(,);
build(root,,n);
for (long long i=;i<=nume;i++)
{
long long u=e[i].u,v=e[i].v,ret=dis[u]+e[i].w+dis[v];
if (e[i].flag) continue;
work(i);
}
for (long long i=;i<=n;i++)
{
long long ret=ask(root,,n,dfn[i]);
if (ret==inf) printf("-1 ");
else printf("%lld ",ret-dis[i]);
}
printf("\n");
return ;
}

BZOJ 3694 最短路的更多相关文章

  1. Bzoj 3694: 最短路 树链剖分

    3694: 最短路 Time Limit: 5 Sec  Memory Limit: 256 MBSubmit: 67  Solved: 34[Submit][Status][Discuss] Des ...

  2. BZOJ 3040 最短路 (堆优化dijkstra)

    这题不是裸的最短路么?但是一看数据范围就傻了.点数10^6,边数10^7.这个spfa就别想了(本来spfa就是相当不靠谱的玩意),看来是要用堆优化dijkstra了.但是,平时写dijkstra时为 ...

  3. BZOJ 3040: 最短路(road) ( 最短路 )

    本来想学一下配对堆的...结果学着学着就偏了... 之前 kpm 写过这道题 , 前面的边不理它都能 AC .. 我也懒得去写前面的加边了... 用 C++ pb_ds 库里的 pairing_hea ...

  4. BZOJ 3040: 最短路(road) [Dijkstra + pb_ds]

    3040: 最短路(road) Time Limit: 60 Sec  Memory Limit: 200 MBSubmit: 2476  Solved: 814[Submit][Status][Di ...

  5. 【刷题】BZOJ 2125 最短路

    Description 给一个N个点M条边的连通无向图,满足每条边最多属于一个环,有Q组询问,每次询问两点之间的最短路径. Input 输入的第一行包含三个整数,分别表示N和M和Q 下接M行,每行三个 ...

  6. BZOJ 2125: 最短路

    2125: 最短路 Time Limit: 1 Sec  Memory Limit: 259 MBSubmit: 756  Solved: 331[Submit][Status][Discuss] D ...

  7. BZOJ.2125.最短路(仙人掌 最短路Dijkstra)

    题目链接 多次询问求仙人掌上两点间的最短路径. 如果是在树上,那么求LCA就可以了. 先做着,看看能不能把它弄成树. 把仙人掌看作一个图(实际上就是),求一遍根节点到每个点的最短路dis[i]. 对于 ...

  8. BZOJ 3040最短路

    题目描述 给定一个 NN 个点, MM 条有向边的带权图,请你计算从 SS 出发,到每个点的距离. 数据保证你能从 SS 出发到任意点. 输入输出格式 输入格式: 第一行两个整数 NN . MM ,表 ...

  9. bzoj 1880 最短路

    我们首先知道,答案肯定是最短路图中的某段公共链,那么设(x,y)为x到y的最短路,那么答案为((s1,t1)+(s2,t2)-min((s1,s2)+(t1,t2),(s1,t2),(s2,t1))) ...

随机推荐

  1. git初识

    下载网上的开发员的项目 git clone https://github.com/xxxxxx/test.git 下载好,进入刚下载的好的test项目目录,可以修改对应的代码,然后 git statu ...

  2. 中国孩子的micro:bit:TurnipBit自制小乐器教程实例

    孩子们是最贪玩的也是最聪明的,因此在过去的数年中,市面上出现了不少寓教于乐的理工科知识(STEM)学习新方法.如今这类产品中又有了一名新成员,TPYBoard重磅推出一款针对小白.中小学生的可编程计算 ...

  3. HDFS架构

  4. [HNOI2009]最小圈

    题目描述 对于一张有向图,要你求图中最小圈的平均值最小是多少,即若一个圈经过k个节点,那么一个圈的平均值为圈上k条边权的和除以k,现要求其中的最小值 输入输出格式 输入格式: 第一行2个正整数,分别为 ...

  5. ADO.Net笔记整理(一)

    几次装机,Notes已烟消云散,近日因为Node.js死活搞不定,无奈装机,备份好的东东,没想到磁盘扇区出现异常,可能是PE启动盘的病毒,只好将磁盘全部重新分区,恢复数据也懒得恢复了,日积月累关乎将来 ...

  6. Python用HTMLTestRunner生成html测试报告

    小编的主机:mac 一.引入HTMLTestRunner包 1.下载HTMLTestRunner.py,已上传到网盘,点击下载 2.将HTMLTestRunner.py复制到python安装目录的Li ...

  7. 列表生成式&amp;生成器表达式

    一.列表生成式 def func(): return [lambda x:i*x for i in range(4)] print([j(2) for j in func()]) 结果:[6,6,6, ...

  8. poj_3274 哈希

    哈希 Hash 哈希是一种将复杂数据转换为线性数据从而可以进行随机访问的查找算法. 哈希经常用于对复杂数据(如结构体.对象等)的查找,在使用的时候,需要定义一个Hash函数,将需要查找的复杂对象转化为 ...

  9. 【洛谷P1272】 重建道路

    重建道路 题目链接 一场可怕的地震后,人们用N个牲口棚(1≤N≤150,编号1..N)重建了农夫John的牧场.由于人们没有时间建设多余的道路,所以现在从一个牲口棚到另一个牲口棚的道路是惟一的.因此, ...

  10. 微信小程序使用相机

    <view class="page-body"> <view class="page-body-wrapper"> <camera ...