BUPT 2017 Summer Training (for 16) #3G

题意

摆好的多米诺牌中有n个关键牌,两个关键牌之间有边代表它们之间有一排多米诺牌。从1号关键牌开始推倒,问最后倒下的牌在哪里,以及时刻。

题解

注意最后倒下的可能不是关键牌,而是关键牌之间的牌。

dfs找出每个关键牌最早到达的时间,也就是它们倒下的时刻。然后再对每条边,计算边上最后倒下的牌的时间。

其实就是跑一遍最短路。

代码

#include <cstdio>
#include <cstring>
#include <algorithm>
#define N 100001
#define inf 0x3f3f3f3f
using namespace std;
struct edge{
int to,next;
double w;
}e[N<<1];
int head[N],cnt;
void add(int u,int v,int w){
e[++cnt]=(edge){v,head[u],(double)w};
head[u]=cnt;
}
int n,m;
int test;
bool one;
int last, second;
double idx[N];
double ans;
void dfs(int x,int fa){
for(int i=head[x];i;i=e[i].next){
int v=e[i].to;
if(v==fa)continue;
if(idx[x]+e[i].w<idx[v]){
idx[v]=idx[x]+e[i].w;
dfs(v,x);
}
}
}
int main(){
while(scanf("%d%d",&n,&m),n||m){
cnt=1;
memset(head,0,sizeof head);
for(int i=1,a,b,l;i<=m;++i){
scanf("%d%d%d",&a,&b,&l);
add(a,b,l);add(b,a,l);
}
printf("System #%d\n",++test);
for(int i=2;i<=n;++i)idx[i]=1000000000.0;
dfs(1,0);
ans=-1;
one=true;
for(int i=1;i<=n;++i){
if(idx[i]>ans){
ans=idx[i];
last=i;
}
}
for(int i=2;i<=cnt;++i){
double time=(idx[e[i].to]+idx[e[i^1].to]+e[i].w)*1./2;
if(time>ans){
ans=time;
one=false;
last=e[i].to;second=e[i^1].to;
}
}
printf("The last domino falls after %.1f seconds, ", ans);
if(one)printf("at key domino %d.\n", last);
else{
if(last>second)swap(last,second);
printf("between key dominoes %d and %d.\n", last, second);
}
puts("");
}
return 0;
}

「POJ 1135」Domino Effect(dfs)的更多相关文章

  1. 「日常训练」「小专题·图论」Domino Effect(1-5)

    题意 分析 这题几乎就是一条dijkstra的问题.但是,如何考虑倒在中间? 要意识到这题求什么:单源最短路的最大值.那么有没有更大的?倒在中间有可能会使它更大. 但是要注意一个问题:不要把不存在的边 ...

  2. 「NOIP 2020」微信步数(计数)

    「NOIP 2020」微信步数(Luogu P7116) 题意: 有一个 \(k\) 维场地,第 \(i\) 维宽为 \(w_i\),即第 \(i\) 维的合法坐标为 \(1, 2, \cdots, ...

  3. POJ 1135 Domino Effect(Dijkstra)

    点我看题目 题意 : 一个新的多米诺骨牌游戏,就是这个多米诺骨中有许多关键牌,他们之间由一行普通的骨牌相连接,当一张关键牌倒下的时候,连接这个关键牌的每一行都会倒下,当倒下的行到达没有倒下的关键牌时, ...

  4. 「专题训练」Machine Schedule(HDU-1150)

    题意 在一个工厂,有两台机器\(A, B\)生产产品.\(A\)机器有\(n\)种工作模式(模式\(0\),模式\(1\)--模式\(n-1\)).\(B\)机器有\(m\)种工作模式(模式\(0\) ...

  5. 「暑期训练」「Brute Force」 Bitonix' Patrol (CFR134D1D)

    题意 有n" role="presentation">nn个站点,排成圆形,每站间距m" role="presentation"> ...

  6. 【POJ - 3984】迷宫问题(dfs)

    -->迷宫问题 Descriptions: 定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0 ...

  7. 「算法笔记」快速傅里叶变换(FFT)

    一.引入 首先,定义多项式的形式为 \(f(x)=\sum_{i=0}^n a_ix^i\),其中 \(a_i\) 为系数,\(n\) 为次数,这种表示方法称为"系数表示法",一个 ...

  8. UVA - 211 The Domino Effect(多米诺效应)(dfs回溯)

    题意:根据多米诺骨牌的编号的7*8矩阵,每个点可以和相邻的点组成的骨牌对应一个编号,问能形成多少种由编号组成的图. 分析:dfs,组成的图必须有1~28所有编号. #pragma comment(li ...

  9. poj 3009 Curling 2.0 (dfs )

    Curling 2.0 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11879   Accepted: 5028 Desc ...

随机推荐

  1. c#中用sql存储过程

    string connstr = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionStri ...

  2. PS 制作彩色烟雾

  3. socket流程

  4. [2017BUAA软工助教]案例分析小结

    BUAA案例分析小结 一.作业要求 http://www.cnblogs.com/jiel/p/7631784.html 二.统计数据 总人数 神策数据 博客园博客 必应词典 30 1 12 17 三 ...

  5. mysql常用命令行操作(一):登陆、退出、查看端口、修改密码、刷新

    一.登陆和退出mysql mysql -u root -p # 登陆exit # 退出 二.查看当前mysql的端口号 show global variables like 'port'; 三.查看用 ...

  6. Docker防主机意外断电导致容器实例无法驱动解决方案:UPS || write barrier || 上btrfs定期snapshot

    Write barrier - Wikipediahttps://en.wikipedia.org/wiki/Write_barrier R大在在介绍CMS时提到了write barrier写屏蔽的概 ...

  7. asp.net mvc导出execl_转载

    public FileResult ExportExcel() { var sbHtml = new StringBuilder(); sbHtml.Append("<table bo ...

  8. 6-2 Verbs and Adjectives with that clauses

    1 Many sentences in English contain two clauses: a main clause and a "that" clause. The &q ...

  9. Oracle Flashback 详解

    Oracle flashback 是一种方便快捷的数据库恢复技术,它不使用备份文件,通过闪回日志可以使数据库恢复到过去的某个状态,当用户发生逻辑错误时(误删表数据.表.表空间等)需要快速恢复数据库,可 ...

  10. linux安装ssh服务

    1.安装openssh-server sudo apt-get install openssh-server 2.检查openssh-server是否安装成功 sudo ps -e | grep ss ...