先传代码再填坑

#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. eclipse打不开,报错 "java was started with exit code=13"

    刚才打开eclipse时,出现如上的报错窗口. 1.查看java 版本,发现是1.8版本,记得自己之前手动安装的java应该是1.7或者更低的版本.让我想起之前系统总是会提醒java有更新,最近就没有 ...

  2. Oracle之多行记录变一行记录,行变列,并排序(wmsys.wm_concat)

    原帖:http://www.cnblogs.com/nayitian/p/3231734.html wmsys.wm_concat Definition: The Oracle PL/SQL WM_C ...

  3. win7的优化-1:隐藏我的电脑导航栏里的收藏等项目

    1. Type regedit in RUN or Start Menu search box and press Enter. It'll open Registry Editor. 2. Now ...

  4. centos6下安装dedecms

    几经波折,终于安装成功!!! 一.centos6下安装WDCP 1.连接linux 在百度直接搜索下载xshell,通过ssh连接 2.安装wdcp 下载安装wget http://dl.wdlinu ...

  5. C# Tostring 格式化输出字符串全解

    C 货币 2.5.ToString("C") ¥2.50 D 十进制数 .ToString("D5") E 科学型 .ToString("E" ...

  6. BZOJ 3631 【JLOI2014】 松鼠的新家

    Description 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在"树&q ...

  7. adb 常用命令

    1.adb shell dumpsys SurfaceFlinger 查看window层结构

  8. Scrapy 爬虫

    Scrapy 爬虫 使用指南 完全教程   scrapy note command 全局命令: startproject :在 project_name 文件夹下创建一个名为 project_name ...

  9. Number of Digit One

    Given an integer n, count the total number of digit 1 appearing in all non-negative integers less th ...

  10. 利用performance属性查看网页性能

    一般我们可以通过浏览器的调试工具-网络面板,或者代理工具查看网页加载过程中的各个阶段的耗时.而利用window.performance属性则可以获得更为精确的原始数据,以毫秒为单位,精确到微秒. pe ...