先传代码再填坑

#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <vector>
#include <queue>
#define N 100005
#define M 400005
#define INF 0x7FFFFFFF using namespace std;
inline int read(){
int ret=0;char ch=getchar();
while (ch<'0' || ch>'9') ch=getchar();
while ('0'<=ch && ch<='9'){
ret=ret*10-48+ch;
ch=getchar();
}
return ret;
} struct STnode{
int l,r;
int tag;
}; int a[N];
struct SegmentTree{
STnode t[4*N];
void PushDown(int x){
if (t[x].l==t[x].r) return;
if (t[x].tag==INF) return;
t[x<<1].tag=min(t[x<<1].tag,t[x].tag);
t[x<<1^1].tag=min(t[x<<1^1].tag,t[x].tag);
t[x].tag=INF;
}
void build(int x,int l,int r){
t[x].l=l;t[x].r=r;t[x].tag=INF;
if (l==r) return;
int mid=(l+r)/2;
build(x<<1,l,mid);
build(x<<1^1,mid+1,r);
}
void modify(int x,int l,int r,int value){
PushDown(x);
if (l<=t[x].l&&t[x].r<=r){
t[x].tag=min(t[x].tag,value);
return;
}
int mid=(t[x].l+t[x].r)/2;
if (l<=mid) modify(x<<1,l,r,value);
if (r>mid) modify(x<<1^1,l,r,value);
}
int getans(int x){
if (t[x].l==t[x].r){a[t[x].l]=t[x].tag;return t[x].tag;}
PushDown(x);
return max(getans(x<<1),getans(x<<1^1));
}
} st; struct edge{
int adj,next,len;
int id;
edge(){}
edge(int _adj,int _next,int _len):adj(_adj),next(_next),len(_len){}
} e[M];
int n,g[N],m;
void AddEdge(int u,int v,int w){
e[++m]=edge(v,g[u],w);g[u]=m;
} struct HeapNode{
int pos,value;
HeapNode(){}
HeapNode(int _pos,int _value):pos(_pos),value(_value){}
};
bool operator >(const HeapNode &x,const HeapNode &y){
return x.value>y.value;
}
priority_queue<HeapNode,vector<HeapNode> ,greater<HeapNode> > h; int fa[N];
int mind[N];
bool flag[N];
int from[N];
void dijkstra(int _s){
memset(mind,127,sizeof(mind));
memset(flag,0,sizeof(flag));
h.push(HeapNode(_s,mind[_s]=0));
fa[_s]=from[_s]=0;
while (!h.empty()){
int u=h.top().pos;
h.pop();
flag[u]=1;
for (int i=g[u];i;i=e[i].next){
int v=e[i].adj;
if (mind[v]>mind[u]+e[i].len){
mind[v]=mind[u]+e[i].len;
h.push(HeapNode(v,mind[v]));
fa[v]=u;from[v]=i;
}
}
while (!h.empty()&&flag[h.top().pos]) h.pop();
}
} int deep[N];
void dfs(int u){
for (int i=g[u];i;i=e[i].next){
int v=e[i].adj;
if (!deep[v]) deep[v]=deep[u];
dfs(v);
}
} void rebuild(){
memset(deep,0,sizeof(deep));
deep[n]=1;
for (int i=n;fa[i];i=fa[i]) deep[fa[i]]=deep[i]+1;
memset(g,0,sizeof(g));m=1;
for (int i=2;i<=n;++i) AddEdge(fa[i],i,0);
dfs(1);
} int u[M],v[M],w[M];
int dist[N]; int main(){
n=read();int m0=read();
memset(g,0,sizeof(g));m=1;
for (int i=1;i<=m0;++i){
u[i]=read();v[i]=read();w[i]=read();
AddEdge(u[i],v[i],w[i]);e[m].id=i;
AddEdge(v[i],u[i],w[i]);e[m].id=i;
}
dijkstra(n);
for (int i=1;i<=n;++i) dist[i]=mind[i];
dijkstra(1);
for (int i=2;i<=n;++i) w[e[from[i]].id]=0;
rebuild();
st.build(1,1,deep[1]-1);
for (int i=1;i<=m0;++i)if (w[i]){
if (deep[u[i]]>deep[v[i]]) swap(u[i],v[i]);
int x=deep[u[i]],y=deep[v[i]];
if (x==y) continue;
st.modify(1,x,y-1,dist[u[i]]+w[i]+mind[v[i]]);
}
int ans=st.getans(1),cnt=0;
for (int i=1;i<deep[1];++i) cnt+=(a[i]==ans);
printf("%d %d\n",ans,ans==mind[n]?m0:cnt);
return 0;
}

  

bzoj4400: tjoi2012 桥的更多相关文章

  1. BZOJ4400 TJOI2012桥(最短路+线段树)

    首先找出任意一条1-n的最短路径.显然删除的边只有在该最短路上才会对最短路长度产生影响. 不会证明地给出一个找不到反例的结论:删除一条边后,新图中一定有一条1-n的最短路径上存在一条边x->y, ...

  2. P2685 [TJOI2012]桥

    P2685 [TJOI2012]桥 思路: 先求出最短路: d1[u] : u 到 1 的最短路, d2[u] : u 到 n 的最短路 再求出一条从 1 到 n 的最短路链,然后从链上的每一个点出发 ...

  3. 洛谷2685 [TJOI2012]桥

    [TJOI2012]桥 题目大意:给定一无向图,求删除一条边后1到n最短路的最大值,以及方案数. 做法:我们先从1为起点.从n为起点跑两边dij,获得每一个点到起点1.终点n的最短距离,其实距离和边权 ...

  4. [TJOI2012]桥(最短路+线段树)

    有n个岛屿, m座桥,每座桥连通两座岛屿,桥上会有一些敌人,玩家只有消灭了桥上的敌人才能通过,与此同时桥上的敌人会对玩家造成一定伤害.而且会有一个大Boss镇守一座桥,以玩家目前的能力,是不可能通过的 ...

  5. [TJOI2012]桥

    Description 有n个岛屿,m座桥,每座桥连通两座岛屿,桥上会有一些敌人,玩家只有消灭了桥上的敌人才能通过,与此同时桥上的敌人会对玩家造成一定伤害.而且会有一个大Boss镇守一座桥,以玩家目前 ...

  6. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  7. BZOJ 3504: [Cqoi2014]危桥 [最大流]

    3504: [Cqoi2014]危桥 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1407  Solved: 703[Submit][Status] ...

  8. hub,桥,交换机,路由器的区别

    1.四种设备在网络中的物理位置 如下图 2.这四种设备的本质 这四种设备,不管怎样,他们都是进行包的转发,只不过转发的行为有些不一样而已 3.逐一介绍 对于hub,一个包过来后,直接将包转发到其他口. ...

  9. 游戏测评-桥梁建造系Poly Bridge破力桥?游戏测评

    最近在b站看到了谜之声的视频:大家来造桥吧! 实在是太搞笑了,看到是一款新出不久还未正式发行的游戏,兴致一来便入手玩了玩.顺手也就写下了这篇测评. POLY BRIDGE 对这个游戏名怎么起个有趣的中 ...

随机推荐

  1. ef操作类

    基于Hi博客的类库 20160811 using Model; using System; using System.Collections.Generic; using System.Data.En ...

  2. C#的匿名方法

    匿名方法是在初始化委托时内联声明的方法. 例如下面这两个例子: 不使用匿名方法的委托: using System; using System.Collections.Generic; using Sy ...

  3. Navigator 对象

    Navigator 对象 Navigator 对象包含有关浏览器的信息. 注意: 没有应用于 navigator 对象的公开标准,不过所有浏览器都支持该对象. Navigator 对象属性 属性 说明 ...

  4. css布局多列等高

    css .content{margin:0 auto;width: 600px;border: 3px solid #00c;overflow: hidden;} .left{float: left; ...

  5. FSL - MELODIC

    Source: http://fsl.fmrib.ox.ac.uk/fsl/fslwiki/MELODIC; https://fsl.fmrib.ox.ac.uk/fsl/fslwiki/MELODI ...

  6. CSS IE6/7/8, Firefox, Safari, Chrome, Opera Hack使用简要归纳(转)

    网上有很多关于IE6/7/8, Firefox, Safari, Chrome, Opera CSS Hack的文章,但我觉得太过繁杂,要不给出一张看也看不懂的CSS Hack归纳表,要不就是给出一大 ...

  7. 使用PHP获取根域名的方法!

    /** * 取得根域名 * @param type $domain 域名 * @return string 返回根域名 */ function GetUrlToDomain($domain) { $r ...

  8. mysql ERROR 1045 (28000): Access denied for user解决方法

    一 这种情况下是 root@% update mysql.user set host='%' where user='root' and host='localhost'; flush privile ...

  9. Linux时间函数之gettimeofday()函数之使用方法

    1.简介: 在C语言中可以使用函数gettimeofday()函数来得到时间.它的精度可以达到微妙 2.函数原型: #include<sys/time.h> int gettimeofda ...

  10. Linux shell中的符号

    .单小括号 () ①命令组.括号中的命令将会新开一个子shell顺序执行,所以括号中的变量不能够被脚本余下的部分使用. 括号中多个命令之间用分号隔开,最后一个命令可以没有分号,各命令和括号之间不必有空 ...