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. 【题解】洛谷P3435 [POI2006] OKR-Periods of Words(KMP)

    洛谷P3435:https://www.luogu.org/problemnew/show/P3435 思路 来自Kamijoulndex大佬的解释 先把题面转成人话: 对于给定串的每个前缀i,求最长 ...

  2. IOS中Hybird实现

    现在Hybird这块,网上也有很多文章,最近研究了下,分享给大家. 什么是Hybird技术? 1.一般是指WebView和Native技术混合而成的一套技术方案 2.也可以理解成,非Native技术与 ...

  3. python类的使用(类定义,构造器,类属性,方法)

    注:这里只描述使用方法,具体类的概念长篇大论就不要为难我这个懒人了. 总之一句话编程语言只是一个工具,会用就行,好用就行.打破砂锅问到底,我觉得有必要研究一下C,汇编,电子链路等. class clt ...

  4. Ubuntu16 安装Anaconda3+tensorflow cpu版

    打开火狐浏览器,下载anaconda安装包,网址:https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/?C=M&O=D 下载完成,到Do ...

  5. Oracle条件判断列数量非where

    sum(case when typename='测试' then 1 else 0 end)

  6. shutil.rmtree()

    shutil.rmtree(path, ignore_errors=False, onerror=None)   #递归地删除文件 def rmtree(path, ignore_errors=Fal ...

  7. Linux 运维工程师学习成长路线上要经历哪四个阶段?

    之前曾看到一篇新闻,Linux之父建议大家找一份基于Linux和开源环境的工作.今天就来聊一聊我的想法,本人8年Linux运维一线经验,呆过很多互联网公司,从一线运维做到运维架构师一职,也见证了中国运 ...

  8. HaoheDI让ETL变得简单

    HaoheDI(昊合数据整合平台)http://www.haohedi.com,产品基于BS架构,开发运维均极为简单,可快速搭建ETL平台,广泛支持各种数据库.文本文件.SAP和Hadoop,开发数据 ...

  9. reids同步机制和远程连接

    RDB同步机制: 开启和关闭:默认情况下是开启了.如果想关闭,那么注释掉redis.conf文件中的所有save选项就可以了. 同步机制: save 900 1:如果在900s以内发生了1次数据更新操 ...

  10. ruby 批量下载王者荣耀皮肤

    主要采用ruby Parallel库提供的多线程方式: require 'unirest' require 'open-uri' require 'parallel' require 'json' u ...