「POJ 1135」Domino Effect(dfs)
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)的更多相关文章
- 「日常训练」「小专题·图论」Domino Effect(1-5)
题意 分析 这题几乎就是一条dijkstra的问题.但是,如何考虑倒在中间? 要意识到这题求什么:单源最短路的最大值.那么有没有更大的?倒在中间有可能会使它更大. 但是要注意一个问题:不要把不存在的边 ...
- 「NOIP 2020」微信步数(计数)
「NOIP 2020」微信步数(Luogu P7116) 题意: 有一个 \(k\) 维场地,第 \(i\) 维宽为 \(w_i\),即第 \(i\) 维的合法坐标为 \(1, 2, \cdots, ...
- POJ 1135 Domino Effect(Dijkstra)
点我看题目 题意 : 一个新的多米诺骨牌游戏,就是这个多米诺骨中有许多关键牌,他们之间由一行普通的骨牌相连接,当一张关键牌倒下的时候,连接这个关键牌的每一行都会倒下,当倒下的行到达没有倒下的关键牌时, ...
- 「专题训练」Machine Schedule(HDU-1150)
题意 在一个工厂,有两台机器\(A, B\)生产产品.\(A\)机器有\(n\)种工作模式(模式\(0\),模式\(1\)--模式\(n-1\)).\(B\)机器有\(m\)种工作模式(模式\(0\) ...
- 「暑期训练」「Brute Force」 Bitonix' Patrol (CFR134D1D)
题意 有n" role="presentation">nn个站点,排成圆形,每站间距m" role="presentation"> ...
- 【POJ - 3984】迷宫问题(dfs)
-->迷宫问题 Descriptions: 定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0 ...
- 「算法笔记」快速傅里叶变换(FFT)
一.引入 首先,定义多项式的形式为 \(f(x)=\sum_{i=0}^n a_ix^i\),其中 \(a_i\) 为系数,\(n\) 为次数,这种表示方法称为"系数表示法",一个 ...
- UVA - 211 The Domino Effect(多米诺效应)(dfs回溯)
题意:根据多米诺骨牌的编号的7*8矩阵,每个点可以和相邻的点组成的骨牌对应一个编号,问能形成多少种由编号组成的图. 分析:dfs,组成的图必须有1~28所有编号. #pragma comment(li ...
- poj 3009 Curling 2.0 (dfs )
Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 11879 Accepted: 5028 Desc ...
随机推荐
- matplotlib 入门之Pyplot tutorial
文章目录 pyplot 介绍 修饰你的图案 格式字符串 [color][marker][line] Colors Markers Line Styles 利用关键字作图(大概是数据映射到属性吧) 传入 ...
- 帮助小白,最新版JDK的安装与环境变量配置(Win 10系统)
学习JAVA,必须首先安装一下JDK(java development kit java开发工具包),之后再配置环境变量就可以开始使用JAVA了. 一,安装JDK 1,可以选择到官网下载最新版本的JD ...
- 【学习总结】vi/vim命令是使用
每次要么想不起来用,要么进去了出不来,真是醉了.痛定思痛此处填坑. 参考教程:菜鸟教程vi/vim 实验环境:借Git-bash宝地一用 注意:记住关键的步骤! 按i a o进入输入模式(即使有时按v ...
- 【学亮IT手记】Servlet的生命周期
1.1 Servlet的生命周期 1.1.1 Servlet的生命周期概述 1.1.1.1 什么是生命周期 生命周期:一个对象从创建到销毁过程. 1.1.1.2 Servlet的生命周期(*****) ...
- 虚拟机安装CentOS7之后没有ip的问题
CentOS 7 默认是不启动网卡的(ONBOOT=no),主要是修改一下网上配置,然后重起便可,看这篇博客操作: https://blog.csdn.net/dancheren/article/de ...
- win10查看无线密码
- Android——MaterialDesign之一Toolbar
Toolbar 由于ActionBar设计原因只能存在活动的顶部,从而不能实现MaterialDesign的效果,现在推荐使用Toolbar,继承Actionbar,但是比起它更加的灵活. 设置主题: ...
- DBExpress动态连接SQL-Server
procedure TForm1.Button1Click(Sender: TObject);var theCNN : TSQLConnection;//定义连接,要引用 DB, SqlExprbe ...
- 天虎云商wap和微信话项目总结
1:架构:以后要采用项目分模块的方式写代码了,不能写一个公用的controller包,每个模块分包,分别建立service,dao,但是模块同级的有个功能的baseDao, BaseSe ...
- Sql server 系统表
sql server系统表详细说明 SQL Server 用户库中系统表说明 名称 说明 备注 syscolumns 每个表和视图中的每列在表中占一行,存储过程中的每个参数在表中也占一行. sys ...