A. Shortest path of the king

time limit per test

1 second

memory limit per test

64 megabytes

input

standard input

output

standard output

The king is left alone on the chessboard. In spite of this loneliness, he doesn't lose heart, because he has business of national importance. For example, he has to pay an official visit to square t. As the king is not in habit of wasting his time, he wants to get from his current position s to square t in the least number of moves. Help him to do this.

In one move the king can get to the square that has a common side or a common vertex with the square the king is currently in (generally there are 8 different squares he can move to).

Input

The first line contains the chessboard coordinates of square s, the second line — of square t.

Chessboard coordinates consist of two characters, the first one is a lowercase Latin letter (from a to h), the second one is a digit from 1 to 8.

Output

In the first line print n — minimum number of the king's moves. Then in n lines print the moves themselves. Each move is described with one of the 8: L, R, U, D, LU, LD, RU or RD.

L, R, U, D stand respectively for moves left, right, up and down (according to the picture), and 2-letter combinations stand for diagonal moves. If the answer is not unique, print any of them.

Examples

input

a8
h1

output

7
RD
RD
RD
RD
RD
RD
RD

解题思路:一个8*8的图,8个方向移动,字符转化为数字表示,bfs记录路径最短路径,到达目标点即遍历结束,记录路径,路径移动方向转变为题中的字符方向。

#include <iostream>
#include <string.h>
#include <stdlib.h>
#include <algorithm>
#include <stdio.h>
#include <queue> using namespace std; int d_x[4] = { 0, 1, -1 };
int d_y[4] = { 0, 1, -1 };
int e[10][10], book[10][10];
int next[2][10000];
int end_xx[10000],end_yy[10000];
int sum;
int start_x, start_y, end_x, end_y; struct node { int pre;
int x, y;
int step;
}; node qt[10000]; void conversion(int x,int y){
if(x==1){
cout<<"R";
}else if(x==-1){
cout<<"L";
} if(y==-1){
cout<<"D";
}else if(y==1){
cout<<"U";
} } void bfs() { int head = 1;
int tail = 1;
node q;
q.x = start_x;
q.y = start_y;
q.pre = head;
q.step = 0; qt[tail] = q;
qt[tail].pre = head;
tail++; queue<node> qq; qq.push( q ); while( !qq.empty() ) { node temp = qq.front(); head = temp.pre; // cout<<"head = "<<head<<endl; if( temp.x == end_x && temp.y == end_y ) { int xx = temp.x;
int yy = temp.y;
sum = 0;
// cout<<"temp.pre = "<<temp.pre<<endl;
int t = qt[temp.pre].pre;
// cout<<"t ="<<t<<endl;
while(true){
// cout<<sum<<endl; end_xx[sum] = xx-qt[t].x;
end_yy[sum] = yy-qt[t].y;
sum++;
xx = qt[t].x;
yy = qt[t].y;
if(t==1) break;
t = qt[t].pre;
} break;
} for(int i=0;i<3;i++){
for(int j =0;j<3;j++){
if(i==0 && j==0) continue;
int dx = temp.x + d_x[i];
int dy = temp.y + d_y[j]; if(dx>8 || dy>8 || dx<1 || dy<1) continue; if(book[dx][dy]==0 ){
book[dx][dy] = 1; node tt;
tt.x = dx;
tt.y = dy;
tt.pre = tail;
tt.step = temp.step+1; qt[tail] = tt;
qt[tail].pre = head;
tail++; qq.push(tt); }
}
} qq.pop(); }
return;
} int main() {
char start[2];
char end[2]; while(cin>>start[0]>>start[1]>>end[0]>>end[1]){ start_x = start[0]-'a'+1;
start_y = start[1]-'0';
end_x = end[0]-'a'+1;
end_y = end[1]-'0'; // cout<<start_x<<" "<<end_x<<endl;
//
// cout<<start_y<<" "<<end_y<<endl;
if(start_x == end_x && start_y == end_y) {
cout<<"0"<<endl;
continue;
} memset( book, 0, sizeof( book ) );
book[start_x][start_y] = 1;
bfs();
cout<<sum<<endl;
for( int i = sum-1 ; i >= 0; i-- ) {
// cout<<end_xx[i]<<" "<<end_yy[i]<<endl;
conversion( end_xx[i], end_yy[i] );
cout<<endl;
}
}
return 0;
}

Codeforces-A. Shortest path of the king(简单bfs记录路径)的更多相关文章

  1. Codeforces 3A-Shortest path of the king(BFS打印路径)

    A. Shortest path of the king time limit per test 1 second memory limit per test 64 megabytes input s ...

  2. node搜索codeforces 3A - Shortest path of the king

    发一下牢骚和主题无关: 搜索,最短路都可以     每日一道理 人生是洁白的画纸,我们每个人就是手握各色笔的画师:人生也是一条看不到尽头的长路,我们每个人则是人生道路的远足者:人生还像是一块神奇的土地 ...

  3. Codeforces Beta Round #3 A. Shortest path of the king 水题

    A. Shortest path of the king 题目连接: http://www.codeforces.com/contest/3/problem/A Description The kin ...

  4. (简单) POJ 3414 Pots,BFS+记录路径。

    Description You are given two pots, having the volume of A and B liters respectively. The following ...

  5. Codeforces Beta Round #3 A. Shortest path of the king

    标题效果: 鉴于国际棋盘两点,寻求同意的操作,是什么操作的最小数量,在操作过程中输出. 解题思路: 水题一个,见代码. 以下是代码: #include <set> #include < ...

  6. A - Shortest path of the king (棋盘)

    The king is left alone on the chessboard. In spite of this loneliness, he doesn't lose heart, becaus ...

  7. Shortest path of the king

    必须要抄袭一下这个代码 The king is left alone on the chessboard. In spite of this loneliness, he doesn't lose h ...

  8. Codeforces 938G Shortest Path Queries [分治,线性基,并查集]

    洛谷 Codeforces 分治的题目,或者说分治的思想,是非常灵活多变的. 所以对我这种智商低的选手特别不友好 脑子不好使怎么办?多做题吧-- 前置知识 线性基是你必须会的,不然这题不可做. 推荐再 ...

  9. CF3A Shortest path of the king

    The king is left alone on the chessboard. In spite of this loneliness, he doesn't lose heart, becaus ...

随机推荐

  1. C++使用按位右移/按位左移运算符

    1.按位右移运算符(>>) 将数据除以2^n(2的n次方) 2.按位左移运算符(<<) 将数据乘以2^n(2的n次方) 使用按位运算符计算数据 #include<iost ...

  2. Mac 开发配置手册

    转自:http://www.cocoachina.com/mac/20141112/10198.html 手册内容为「如何让一部全新的 MacBook 快速完成开发环境配置」,主要面向 Web 开发者 ...

  3. C语言中内存分配

     C语言中内存分配   在任何程序设计环境及语言中,内存管理都十分重要.在目前的计算机系统或嵌入式系统中,内存资源仍然是有限的.因此在程序设计中,有效地管理内存资源是程序员首先考虑的问题. 第1节主要 ...

  4. IDEA(2018.3.2)

    N757JE0KCT-eyJsaWNlbnNlSWQiOiJONzU3SkUwS0NUIiwibGljZW5zZWVOYW1lIjoid3UgYW5qdW4iLCJhc3NpZ25lZU5hbWUiO ...

  5. MySQL学习之视图的使用

    视图基本操作 创建视图 视图的本质就是SQL指令(select语句) 基本语法:create view 视图名 as  select 指令; 在这里的select指令可以是单表数据,也可以是连接查询. ...

  6. wordpress | 网站访问速度优化方案(Avada)

    一.谷歌字体 原因: Wordpress系统默认使用谷歌字体,在国内谷歌域名被屏蔽,所以导致操作反应慢. 解决方法: 对于后台:找到Wordpress这个文件 /wp-includes/script- ...

  7. Angular.js进阶

    1.常用指令 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UT ...

  8. vuejs 预渲染插件 prerender-spa-plugin 生成多页面 -- SEO

    前端vue等框架打包的项目一般为SPA应用,而单页面是不利于SEO的,现在的解决方案有两种: 1.SSR服务器渲染   了解服务器渲染请进,这里不做记录. 2.预渲染模式   这比服务端渲染要简单很多 ...

  9. PHP对接QQ互联,超级详细!!!

    SDK下载

  10. Python学习 :迭代器&生成器

    列表生成式 列表生成式的操作顺序: 1.先依次来读取元素 for x 2.对元素进行操作 x*x 3.赋予变量 Eg.列表生成式方式一 a = [x*x for x in range(10)] pri ...