UVA-810 A Dicey Problem (BFS)
题目大意:滚骰子游戏,骰子的上面的点数跟方格中的数相同时或格子中的数是-1时能把格子滚过去,找一条从起点滚到起点的路径。
题目大意:简单BFS,状态转移时细心一些即可。
代码如下;
# include<iostream>
# include<cstdio>
# include<map>
# include<string>
# include<queue>
# include<cstring>
# include<algorithm>
using namespace std; struct Node
{
int x,y,s,t;
string px,py;
Node(int _x,int _y,int _s,int _t,string _px,string _py):x(_x),y(_y),s(_s),t(_t),px(_px),py(_py){}
bool operator < (const Node &a) const {
return t>a.t;
}
};
int Left[50],Right[50],vis[10][10][50],mp[10][10],r,c;
int behind[6]={6,5,4,3,2,1};
int d[4][2]={{-1,0},{1,0},{0,-1},{0,1}};
string name; void init()
{
Left[9]=4,Right[9]=3;
Left[12]=3,Right[12]=4;
Left[10]=2,Right[10]=5;
Left[11]=5,Right[11]=2; Left[15]=3,Right[15]=4;
Left[20]=4,Right[20]=3;
Left[18]=1,Right[18]=6;
Left[17]=6,Right[17]=1; Left[22]=5,Right[22]=2;
Left[27]=2,Right[27]=5;
Left[23]=1,Right[23]=6;
Left[26]=6,Right[26]=1; Left[29]=2,Right[29]=5;
Left[34]=5,Right[34]=2;
Left[30]=6,Right[30]=1;
Left[33]=1,Right[33]=6; Left[36]=4,Right[36]=3;
Left[41]=3,Right[41]=4;
Left[38]=1,Right[38]=6;
Left[39]=6,Right[39]=1; Left[44]=3,Right[44]=4;
Left[47]=4,Right[47]=3;
Left[46]=2,Right[46]=5;
Left[45]=5,Right[45]=2;
} bool ok(int x,int y)
{
return x>=0&&x<r&&y>=0&&y<c;
} void bfs(int sx,int sy,int ss)
{
priority_queue<Node>q;
memset(vis,0,sizeof(vis));
string path="";
q.push(Node(sx,sy,ss,0,path+(char)(sx+'A'),path+(char)(sy+'A')));
while(!q.empty())
{
Node u=q.top();
q.pop(); if(u.t&&u.x==sx&&u.y==sy){
int l=u.px.size();
for(int i=0;i<l;++i){
if(i==0)
printf(" ");
printf("(%d,%d)",u.px[i]-'A'+1,u.py[i]-'A'+1);
if(i==l-1)
printf("\n");
else if(i%9==8)
printf(",\n ");
else
printf(",");
}
return ;
} int dd[4]={u.s%7,behind[u.s%7-1],Right[u.s],Left[u.s]};
for(int i=0;i<4;++i){
int nx=u.x+d[i][0],ny=u.y+d[i][1];
if(ok(nx,ny)&&(mp[nx][ny]==(u.s/7)||mp[nx][ny]==-1)){
int k=u.s%7;
if(i==0)
k=behind[u.s/7-1];
if(i==1)
k=u.s/7;
if(!vis[nx][ny][dd[i]*7+k]){
vis[nx][ny][dd[i]*7+k]=1;
q.push(Node(nx,ny,dd[i]*7+k,u.t+1,u.px+(char)(nx+'A'),u.py+(char)(ny+'A')));
}
}
}
}
printf(" No Solution Possible\n");
} int main()
{
//freopen("UVA-810 A Dicey Problem.txt","r",stdin);
int sx,sy,st,sf;
init();
while(cin>>name)
{
if(name=="END")
break;
scanf("%d%d%d%d%d%d",&r,&c,&sx,&sy,&st,&sf);
for(int i=0;i<r;++i)
for(int j=0;j<c;++j)
scanf("%d",&mp[i][j]);
cout<<name<<endl;
bfs(sx-1,sy-1,st*7+sf);
}
return 0;
}
UVA-810 A Dicey Problem (BFS)的更多相关文章
- UVA 810 - A Dicey Problem(BFS)
UVA 810 - A Dicey Problem 题目链接 题意:一个骰子,给你顶面和前面.在一个起点,每次能移动到周围4格,为-1,或顶面和该位置数字一样,那么问题来了,骰子能不能走一圈回到原地, ...
- UVa 1363 - Joseph's Problem(数论)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVa 1640 - The Counting Problem(数论)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVa 439骑士的移动(BFS)
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVa 816 Abbott的复仇(BFS)
寒假的第一道题目,在放假回家颓废了两天后,今天终于开始刷题了.希望以后每天也能多刷几道题. 题意:这道BFS题还是有点复杂的,给一个最多9*9的迷宫,但是每个点都有不同的方向,每次进入该点的方向不同, ...
- Uva - 810 - A Dicey Problem
根据状态进行bfs,手动打表维护骰子滚动. AC代码: #include <iostream> #include <cstdio> #include <cstdlib&g ...
- UVA - 816 Abbott's Revenge(bfs)
题意:迷宫从起点走到终点,进入某点的朝向不同,可以出去的方向也不同,输出最短路. 分析:因为朝向决定接下来在该点可以往哪里走,所以每个点需要有三个信息:x,y,d(坐标和进入该点的朝向),所以将起点的 ...
- SDUT OJ 数据结构实验之图论五:从起始点到目标点的最短步数(BFS)
数据结构实验之图论五:从起始点到目标点的最短步数(BFS) Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss P ...
- SDUT-2139_从起始点到目标点的最短步数(BFS)
数据结构实验之图论五:从起始点到目标点的最短步数(BFS) Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 在古老的魔兽 ...
随机推荐
- MySQL 慢查询日志工具之pt-query-digest
1. 工具简介 pt-query-digest是用于分析mysql慢查询的一个工具,它可以分析binlog.General log.slowlog,也可以通过SHOWPROCESSLIST或者通过tc ...
- Windows:子线程中创建窗口
一般来讲,UI的所有操作都必须在主线程,否则会出现未知错误.但有时候我们会需要一个功能比较单一的窗口,同时希望他在一个单独的线程运行.并不影响主线程的效率. 下面说明一下新建子线程创建的新窗口的方法, ...
- 用 chown 和 chmod 修改目录所属用户及权限
1.修改 tmp 目录所属用户为 root,用户组为 root chown -R root:root /tmp12.修改 tmp 目录为可写权限 chmod -R 777 /tmp
- 爬虫之selenium使用
详细使用链接: 点击链接 selenium介绍: selenium最初是一个自动化测试工具,而爬虫中使用它主要是为了解决requests无法直接执行JavaScript代码的问题 selenium本质 ...
- python 面向对象 公有属性 用在哪里
公有属性也可以叫做静态字段 如果每个对象都有一个共同的值 , 应该把它设置为公有属性 公有属性使用场景,每个对象中保存相同的东西时,可以使用公有属性 类找公有属性 过程
- 创建WCF服务的过程
一.创建控制台WCF工程 1.创建一个控制台工程2.System.ServiceModel的引用3.可创建多个WCF服务,如:IService.cs和Service.cs 顺序:右键->添 ...
- 基于 Spark 的文本情感分析
转载自:https://www.ibm.com/developerworks/cn/cognitive/library/cc-1606-spark-seniment-analysis/index.ht ...
- HDU1452:Happy 2004(求因子和+分解质因子+逆元)上一题的简单版
题目链接:传送门 题目要求:求S(2004^x)%29. 题目解析:因子和函数为乘性函数,所以首先质因子分解s(2004^x)=s(2^2*x)*s(3^x)*s(167^x); 因为2与29,166 ...
- zw版【转发·台湾nvp系列Delphi例程】HALCON SubImage
zw版[转发·台湾nvp系列Delphi例程]HALCON SubImage procedure TForm1.Button1Click(Sender: TObject);var op : HOper ...
- hdu 5187 快速幂 + 快速乘 值得学习
就是以那个ai为分水岭,左边和右边都分别是单调增或单调减如图 就这四种情况,其中头两种总共就是两个序列,也就是从头到尾递增和从头到尾递减. 后两种方式就是把序列中德数分 ...