HNU OJ10320 穿越火线 简单模拟
| 穿越火线 |
| Time Limit: 10000ms, Special Time Limit:25000ms, Memory Limit:65536KB |
| Total submit users: 12, Accepted users: 9 |
| Problem 10320 : No special judgement |
| Problem description |
| 对于窃取情报和破译密码,Feli简直就是天才!在抗日作战中,Feli已经多次成功的窃取日伪军的重要情报,为我军获取了大量作战取胜的关键筹码。 这天,Feli又一次成功破译了对方的秘密电报。电报的内容为: 明天凌晨2:00,所有部队集中埋伏剿灭土八路3721整编军,天皇万福,保佑这次偷袭成功! Feli知道我军3721整编军是我军一支重点培养的生力军,如果在这次行动中遭受损失,那对我军将是一个十分严重的实力打击。这么重要的消息,必须赶紧传达到指挥步!由于抗战期间交通十分落后,Feli只好委托Lucky连夜将该消息送达总部。接到委托,Lucky立即启程。 从情报站到指挥部之间有许多错综交叉的道路,道路和道路的交叉处都有地方可以供Lucky躲藏。由于这里是交通要道,敌人也对这个地带十分关注:他们会时不时对在某些道路上派人巡逻。虽然Lucky可以用精准的枪法将他们干掉,但是现在身负重任,不能打草惊蛇,所以必须避开他们。这意味着,如果某条道路有人巡逻,那么Lucky将无法穿过。时间紧迫,Lucky必须尽快到达总部。现在Lucky再次向你求助,他应该如何行走才能用最短的时间到达指挥部。 说明:在每个交叉路口,Lucky都能选择躲藏和行走。敌人的巡逻是周期循环的,他们总是以分钟为单位巡逻某条道路,在该分钟过去后离开。针对每条道路,我们假设Lucky总是刚好用1分钟时间走完。 针对下列数据: V={1,2,3,4,5}; E={(1,2),(2,3),(3,4),(2,4),(4,5),(1,3),(3,5)} 结点1为情报站,5为指挥部,其余为交叉路口。 周期为4分钟。 每个周期的第1分钟有巡逻的边为{(1,2),(2,4),(4,5)} 每个周期的第2分钟有巡逻的边为{(1,3),(2,3),(3,5)} 每个周期的第3分钟有巡逻的边为{(3,4),(4,5)} 每个周期的第4分钟没有巡逻边。 这样,Lucky可以在第一分钟走边(1,3),第二分钟躲藏,第3分钟走边(3,5),消耗3分钟,时间最短。 |
| Input |
每组输入数据第一行有2个整数n和m(1≤n≤100; 1≤m≤500),代表地图有n个结点m条边。1号结总是代表情报站,n号结点总是代表指挥部。 |
| Output |
| 输出数据仅有一行,如果Lucky可以到达指挥部,则输出到达指挥部的最短时间。如果不能到达则输出“No solution.” |
| Sample Input |
5 7 |
| Sample Output |
3 |
| Problem Source |
| HNU Contest |
题目链接:http://acm.hnu.cn/online/?action=problem&type=show&id=10320
题意很明确,我就不说了,判断连续两个周期,a[n]数组是不是一致,a[i]记录到到i的最早时间
这题还有一个大坑:就是有k=0,这个时候随便搞一下看看能不能从1到n,我就是一直wa,666
这是打湖南大学新生赛的时候写,写的很恶心,。。。。。。
/*
User: 96655 , Problem : 10320
Language : GNU C++ , Judge Result: Accepted
Source Code
*/
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cmath>
#include<cstdlib>
#include<vector>
#include<queue>
using namespace std;
typedef long long LL;
const int INF=0x3f3f3f3f;
int mp[][];
bool tt[][];
vector<int>g[];
int a[];
int b[];
int n,m;
bool judge()
{
for(int i=; i<=n; i++)
if(a[i]!=b[i])return ;
return ;
}
void bfs()
{
queue<int>q;
q.push();
while(!q.empty())
{
int u=q.front();
q.pop();
for(int i=;i<g[u].size();++i)
{
int v=g[u][i];
if(a[v])continue;
a[v]=a[u]+;
q.push(v);
}
}
}
int main()
{
while(~scanf("%d%d",&n,&m))
{
memset(mp,,sizeof(mp));
memset(tt,,sizeof(tt));
memset(a,INF,sizeof(a));
for(int i=; i<=n; ++i)
g[i].clear();
for(int i=; i<=m; i++)
{
int u,v;
scanf("%d%d",&u,&v);
g[u].push_back(v);
g[v].push_back(u);
if(mp[u][v]==)
mp[u][v]=mp[v][u]=i;
}
int k;
scanf("%d",&k);
if(k==)
{
memset(a,,sizeof(a));
bfs();
if(a[n])printf("%d\n",a[n]);
else printf("No solution.\n");
continue;
}
for(int i=; i<=k; i++)
{
int u,v;
while()
{
scanf("%d%d",&u,&v);
if(u==)break;
int id=mp[u][v];
tt[id][i]=;
}
}
a[]=;
int s=,t=k,flag=;
while(flag||judge())
{
if(flag)flag=;
else s+=k,t+=k;
for(int i=s; i<=t ; i++)
{
for(int j=; j<=n; j++)
{
if(a[j]==INF)continue;
int u=j;
for(int p=; p<g[u].size(); p++)
{
int v=g[u][p];
int id=mp[u][v];
int c=i%k;
if(c==)c=k;
if(tt[id][c]==)
if(a[v]==INF&&a[u]!=i)a[v]=i;
if(a[n]!=INF)break;
}
if(a[n]!=INF)break;
}
if(a[n]!=INF)break;
}
if(a[n]!=INF)break;
for(int i=; i<=n; i++)
b[i]=a[i];
s+=k,t+=k;
for(int i=s; i<=t ; i++)
{
for(int j=; j<=n; j++)
{
if(a[j]==INF)continue;
int u=j;
for(int p=; p<g[u].size(); p++)
{
int v=g[u][p];
int id=mp[u][v];
int c=i%k;
if(c==)c=k;
if(tt[id][c]==)
if(a[v]==INF&&a[u]!=i)a[v]=i;
if(a[n]!=INF)break;
}
if(a[n]!=INF)break;
}
if(a[n]!=INF)break;
}
if(a[n]!=INF)break;
}
if(a[n]==INF)printf("No solution.\n");
else printf("%d\n",a[n]);
}
return ;
}
HNU OJ10320 穿越火线 简单模拟的更多相关文章
- java web学习总结(二十二) -------------------简单模拟SpringMVC
在Spring MVC中,将一个普通的java类标注上Controller注解之后,再将类中的方法使用RequestMapping注解标注,那么这个普通的java类就够处理Web请求,示例代码如下: ...
- WPF简单模拟QQ登录背景动画
介绍 之所以说是简单模拟,是因为我不知道QQ登录背景动画是怎么实现的.这里是通过一些办法把它简化了,做成了类似的效果 效果图 大体思路 首先把背景看成是一个4行8列的点的阵距,X轴Y轴都是距离70.把 ...
- Linux 内核 链表 的简单模拟(2)
接上一篇Linux 内核 链表 的简单模拟(1) 第五章:Linux内核链表的遍历 /** * list_for_each - iterate over a list * @pos: the & ...
- Linux 内核 链表 的简单模拟(1)
第零章:扯扯淡 出一个有意思的题目:用一个宏定义FIND求一个结构体struct里某个变量相对struc的编移量,如 struct student { int a; //FIND(struct stu ...
- JavaWeb学习总结(四十九)——简单模拟Sping MVC
在Spring MVC中,将一个普通的java类标注上Controller注解之后,再将类中的方法使用RequestMapping注解标注,那么这个普通的java类就够处理Web请求,示例代码如下: ...
- 简单模拟Hibernate的主要功能实现
在学习期间接触到Hibernate框架,这是一款非常优秀的O/R映射框架,大大简化了在开发web项目过程中对数据库的操作.这里就简单模拟其底层的实现. /*******代码部分,及其主要注解***** ...
- 【HDU 4452 Running Rabbits】简单模拟
两只兔子Tom和Jerry在一个n*n的格子区域跑,分别起始于(1,1)和(n,n),有各自的速度speed(格/小时).初始方向dir(E.N.W.S)和左转周期turn(小时/次). 各自每小时往 ...
- Jquery源码分析与简单模拟实现
前言 最近学习了一下jQuery源码,顺便总结一下,版本:v2.0.3 主要是通过简单模拟实现jQuery的封装/调用.选择器.类级别扩展等.加深对js/Jquery的理解. 正文 先来说问题: 1. ...
- (hdu step 8.1.6)士兵队列训练问题(数据结构,简单模拟——第一次每2个去掉1个,第二次每3个去掉1个.知道队伍中的人数<=3,输出剩下的人 )
题目: 士兵队列训练问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...
随机推荐
- C# Windows - RadioButton&CheckBox
RadioButton和CheckBox控件与Button控件有相同的基类,但它们的外观和用法大不相同. RadioButton显示为一个标签,左边是一个圆点,该点可以是选中或未选中.用在给用户提供两 ...
- 17款免费的Bootstrap后台管理模板集合
Bootstrap是Twitter推出的一个用于前端开发的开源工具包.是目前最受欢迎的前端框架之一.下面为大家推荐17个免费的Bootstrap后台管理界面模板. 1. Admin Lite ...
- WPF MultiDataTrigger
huhu <Style x:Key="Cell" TargetType="{x:Type Button}"> <Setter Property ...
- thinkphp 分组
分组 配置项: // 开启分组 'APP_GROUP_LIST'=>'Home,Admin', // 默认分组 'DEFAULT_GROUP'=>'Home', 涉及分组: 配置文件分组, ...
- Qt串口通信接收数据不完整的解决方法(传输图片)
在使用串口接收数据时,当数据量大的时候会出现数据接收不完整的情况.因为串口数据获取函数readAll()由readyRead()信号触发,但readyRead()信号在串口读到起始标志时立即发送,并不 ...
- Delphi函数翻译成VC要注意句柄指针传递(传递Handle的时候,必须加上一个指针引用,才能消除编译错误)
Delphi里做了魔法变化,每个变量名称本身就是指针,因为不怎么需要指针语法.我也不知道是不是因为这个原因引起的Delphi与VC对句柄的不同处理. 这是Delphi的强行关机函数,好用,调用方式:W ...
- yii执行原理
应用执行流程: 浏览器向服务器发送 Http Request | 控制器(protected/controllers) | |---> Action | 创建模型 (Model) | 检查$_P ...
- CAS SiteMinder (单点登录)
http://www.ibm.com/developerworks/cn/opensource/os-cn-cas/
- Why it is good practice to declare loggers private, static, and final?
// Jakarta Commons Loggingprivate static final Log log = LogFactory.getLog(MyClass.class);The above ...
- MySQL数据库乱码 - Linux下乱码问题一
乱码问题是很让人抓狂的问题,下面我将记录一下linux下mysql乱码问题的解决方法. mysql在linux下乱码问题 一.操作 mysql默认字符集是latin1,但是我们大部分程序使用的字符集是 ...