模拟赛20181015 Uva1078 bfs+四维dp
题意:一张网格图,多组数据,输入n,m,sx,sy,tx,ty大小,起终点
接下来共有2n-1行,奇数行有m-1个数,表示横向的边权,偶数行有m个数,表示纵向的边权
样例输入:
4 4 1 1 4 4
10 10 10
9 0 0 10
0 0 0
9 0 0 10
0 9 0 10
0 9 9
2 2 1 1 2 2
0
1 1
0
0 0 0 0 0 0
样例输出:
Case 1: 100
Case 2: Impossible
我们发现此题的特点在于允许转向,也就是说我们可以将转向的状态利用一维表示出来以进行转移
同时由于起终点也需要*2,我们干脆新开两维,一维表示是否*2,另一维表示当前已经操作后面对的方向
利用spfa进行转移即可
#include<bits/stdc++.h>
#define rep(i,x,y) for(register int i=x;i<=y;i++)
using namespace std;
const int NN=;
const int NNN=;
const int inf=;
inline int read(){
int x=,f=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-;ch=getchar();}
while(isdigit(ch)){x=(x<<)+(x<<)+(ch^);ch=getchar();}
return x*f;} int g[NN][];
int d[NNN];
bool vis[NNN]; int dx[]={,,,-};
int dy[]={,-,,}; int n,m,sx,sy,tx,ty,x,y,t,idx,w;
struct node{int x,y,t;};queue<node> q; inline int calc(int x,int y){return (x-)*m+(y-);}
inline int calc(int x,int y,int t){return calc(x,y)*+t;}
bool check(int x,int y){return <=x&&x<=n&&<=y&&y<=m;} int main(){
while(scanf("%d%d%d%d%d%d",&n,&m,&sx,&sy,&tx,&ty)!=EOF&&n&&m){ rep(i,,*n-)
if(i&) rep(y,,m-){
x=(i+)/,w=read();if(!w) w=inf;
g[calc(x,y)][]=g[calc(x,y+)][]=w;}
else rep(y,,m){
x=i/,w=read();if(!w) w=inf;
g[calc(x,y)][]=g[calc(x+,y)][]=w;}
//t代表的状态是身后已经加的边的状态 memset(d,,sizeof d);
d[calc(sx,sy,)]=;
vis[calc(sx,sy,)]=;
q.push((node){sx,sy,}); while(!q.empty()){
x=q.front().x;
y=q.front().y;
t=q.front().t;q.pop();
vis[calc(x,y,t)]=; // 4 前后都要二倍
if(t<){// i-i
int xx=x+dx[t],yy=y+dy[t];
if(!check(xx,yy)) continue;
int w=g[calc(x,y)][t];
if(d[calc(xx,yy,t)]>d[calc(x,y,t)]+w){
d[calc(xx,yy,t)]=d[calc(x,y,t)]+w;
if(!vis[calc(xx,yy,t)])
vis[calc(xx,yy,t)]=,q.push((node){xx,yy,t});}
w=w*;//i-4
if(d[calc(xx,yy,)]>d[calc(x,y,t)]+w){
d[calc(xx,yy,)]=d[calc(x,y,t)]+w;
if(!vis[calc(xx,yy,)])
vis[calc(xx,yy,)]=,q.push((node){xx,yy,});}
}else{
for(int i=;i<=;i++){
int xx=x+dx[i],yy=y+dy[i];
if(!check(xx,yy)) continue;
int w=g[calc(x,y)][i]*; //4 是转向所以w跟随i变化
// 4-i
if(d[calc(xx,yy,i)]>d[calc(x,y,t)]+w){
d[calc(xx,yy,i)]=d[calc(x,y,t)]+w;
if(!vis[calc(xx,yy,i)])
vis[calc(xx,yy,i)]=,q.push((node){xx,yy,i});}
// 4-4
if(d[calc(xx,yy,)]>d[calc(x,y,t)]+w){
d[calc(xx,yy,)]=d[calc(x,y,t)]+w;
if(!vis[calc(xx,yy,)])
vis[calc(xx,yy,)]=,q.push((node){xx,yy,});
}
}
}/*
i-i 正常直走
i-4 决策 转弯的第一条边
到达终点
4-i 决策 转弯的第二条边
起点结束
4-4 决策 转弯到终点
决策 连续转弯
*/
}// 三维状态 二维权值
int ans=d[calc(tx,ty,)];
if(ans>=inf) printf("Case %d: Impossible\n",++idx);
else printf("Case %d: %d\n",++idx,ans);
}return ;
}
完结撒花
模拟赛20181015 Uva1078 bfs+四维dp的更多相关文章
- 6.28 NOI模拟赛 好题 状压dp 随机化
算是一道比较新颖的题目 尽管好像是两年前的省选模拟赛题目.. 对于20%的分数 可以进行爆搜,对于另外20%的数据 因为k很小所以考虑上状压dp. 观察最后答案是一个连通块 从而可以发现这个连通块必然 ...
- 「模拟赛20190327」 第二题 DP+决策单调性优化
题目描述 小火车虽然很穷,但是他还是得送礼物给妹子,所以他前往了二次元寻找不需要钱的礼物. 小火车准备玩玩二次元的游戏,游戏当然是在一个二维网格中展开的,网格大小是\(n\times m\)的,某些格 ...
- 【noip模拟赛7】上网 线性dp
描述 假设有n个人要上网,却只有1台电脑可以上网.上网的时间是从1 szw 至 T szw ,szw是sxc,zsx,wl自创的时间单位,至于 szw怎么换算成s,min或h,没有人清楚.依次给出每个 ...
- 【noip模拟赛5】任务分配 降维dp
描述 现有n个任务,要交给A和B完成.每个任务给A或给B完成,所需的时间分别为ai和bi.问他们完成所有的任务至少要多少时间. 输入 第一行一个正整数n,表示有n个任务.接下来有n行,每行两个正整数a ...
- 2017-5-14 湘潭市赛 Similar Subsequence 分析+四维dp+一些简单优化
Similar Subsequence Accepted : Submit : Time Limit : MS Memory Limit : KB Similar Subsequence For gi ...
- (计数器)NOIP模拟赛(神奇的数位DP题。。)
没有原题传送门.. 手打原题QAQ [问题描述] 一本书的页数为N,页码从1开始编起,请你求出全部页码中,用了多少个0,1,2,…,9.其中—个页码不含多余的0,如N=1234时第5页不是00 ...
- codehunter 「Adera 6」杯省选模拟赛 网络升级 【树形dp】
直接抄ppt好了--来自lyd 注意只用对根判断是否哟留下儿子 #include<iostream> #include<cstdio> using namespace std; ...
- 「模拟赛20191019」B 容斥原理+DP计数
题目描述 将\(n\times n\)的网格黑白染色,使得不存在任意一行.任意一列.任意一条大对角线的所有格子同色,求方案数对\(998244353\)取模的结果. 输入 一行一个整数\(n\). 输 ...
- 「模拟赛20191019」A 简单DP
题目描述 给一个\(n\times m\)的网格,每个格子上有一个小写字母. 对于所有从左上角\((1,1)\)到右下角\((n,m)\)只向下或向右走的路径构成的集合,判断是否存在两条走法不同的路径 ...
随机推荐
- 周一04.2流程控制if……else
语法一: if 条件1: 代码1 代码2 例题:如果年龄>20岁,那么:叫阿姨 age=22if age>20: print('阿姨') 语法二: if 条件1: 代码1 代码2else ...
- wordpress如何利用插件添加优酷土豆等视频到自己的博客上
wordpress有时候需要添加优酷.土豆等网站的视频到自己的博客上,传统的分享方法不能符合电脑端和手机端屏幕大小的需求,又比较繁琐,怎样利用插件的方法进行添加呢,本视频向你介绍一款这样的插件——Sm ...
- Java第二次作业程序设计作业
本次作业包含两个部分:一是以下4个题目的程序源码和运行结果截图:二是本次作业的小结(谈谈你在做作业的过程中遇到了哪些问题,如何解决,有哪些收获). 1.编写"人"类及其测试类. 1 ...
- ansible-playbook(nginx例)
一.创建目录结构 cd /etc/ansible/roles/ mkdir nginx/{files,templates,vars,handlers,meta,default,tasks} -pv 二 ...
- OSI七层模型的每一层都有哪些协议
TCP/IP: 数据链路层:ARP,RARP 网络层: IP,ICMP,IGMP 传输层:TCP ,UDP,UGP 应用层:Telnet,FTP,SMTP,SNMP. OSI: 物理层:EIA/TIA ...
- Markdown语法基础
Markdown基本语法 创建 2018-09-07 by YANHAI 标题:Setext方式 三个或更多 大标题 === 小标题 --- 大标题 小标题 标题:Atx方式 # 内容 (一级标题) ...
- git配置ssh秘钥(公钥以及私钥)
桌面版git, 本文以github为例,gitlab等其它托管平台一样操作 当我们将代码托管到远程平台(GitHub.gitlab等)时, 我们需要在本地使用git进行push/pull代码时,需要 ...
- Vue.js 2.x笔记:状态管理Vuex(7)
1. Vuex简介与安装 1.1 Vuex简介 Vuex是为vue.js应用程序开发的状态管理模式,解决的问题: ◊ 组件之间的传参,多层嵌套组件之间的传参以及各组件之间耦合度过高问题 ◊ 不同状态中 ...
- Git 之 恢复修改的文件
对于恢复修改的文件,就是将文件从仓库中拉到本地工作区,即 仓库区 ----> 暂存区 ----> 工作区. 对于修改的文件有两种情况: 只是修改了文件,没有任何 git 操作 修改了文件, ...
- Magento 2 自带模态的应用
Modal widget in Magento 2 Magento 2 自带模态的应用 使用magento 2 的自带模态组件,以下代码只供参考使用. 1,DOM >模态块与触发元素 .pthm ...