#include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
#include <iostream>
using namespace std;
#define LL __int64
#define mod 9973
#define N 100010 int ma[10][10];
int f1[10][10];
int f2[10][10];
int f3[10][10]; struct asd{
int x,y;
int step;
};
asd q[N];
int head,tail;
int dx[8]={-2,-2,-1,-1,1,1,2,2};
int dy[8]={1,-1,2,-2,2,-2,1,-1}; void bfs1(int x,int y)
{
memset(f1,-1,sizeof(f1));
head=0;
tail=1;
q[head].x=x;
q[head].y=y;
f1[x][y]=0;
while(head<tail)
{
int a=q[head].x;
int b=q[head].y;
for(int i=0;i<8;i++)
{
int aa=a+dx[i];
int bb=b+dy[i];
if(aa<1||bb<1||aa>8||bb>8||f1[aa][bb]!=-1)
continue;
q[tail].step=q[head].step+1;
f1[aa][bb]=q[tail].step;
q[tail].x=aa;
q[tail].y=bb;
tail++;
}
head++;
}
} void bfs2(int x,int y)
{
memset(f2,-1,sizeof(f2));
head=0;
tail=1;
q[head].x=x;
q[head].y=y;
f2[x][y]=0;
while(head<tail)
{
int a=q[head].x;
int b=q[head].y;
for(int i=0;i<8;i++)
{
int aa=a+dx[i];
int bb=b+dy[i];
if(aa<1||bb<1||aa>8||bb>8||f2[aa][bb]!=-1)
continue;
q[tail].step=q[head].step+1;
f2[aa][bb]=q[tail].step;
q[tail].x=aa;
q[tail].y=bb;
tail++;
}
head++;
}
}
void bfs3(int x,int y)
{
memset(f3,-1,sizeof(f3));
head=0;
tail=1;
q[head].x=x;
q[head].y=y;
f3[x][y]=0;
while(head<tail)
{
int a=q[head].x;
int b=q[head].y;
for(int i=0;i<8;i++)
{
int aa=a+dx[i];
int bb=b+dy[i];
if(aa<1||bb<1||aa>8||bb>8||f3[aa][bb]!=-1)
continue;
q[tail].step=q[head].step+1;
f3[aa][bb]=q[tail].step;
q[tail].x=aa;
q[tail].y=bb;
tail++;
}
head++;
}
} int main()
{
int T;
scanf("%d",&T);
int x1,x3,x2,y1,y2,y3;
while(T--)
{
char a1[5];
char a2[5];
char a3[5];
scanf("%s%s%s",a1,a2,a3);
x1=a1[0]-'A'+1;
y1=a1[1]-'0';
x2=a2[0]-'A'+1;
y2=a2[1]-'0';
x3=a3[0]-'A'+1;
y3=a3[1]-'0';
bfs1(x1,y1);
bfs2(x2,y2);
bfs3(x3,y3);
int ans=1000;
for(int i=1;i<=8;i++)
{
for(int j=1;j<=8;j++)
{
ans=min(f1[i][j]+f2[i][j]+f3[i][j],ans);
}
}
printf("%d\n",ans);
}
return 0;
}

hihoCoder搜索二·骑士问题的更多相关文章

  1. hiho #1308 : 搜索二·骑士问题

    #1308 : 搜索二·骑士问题 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi:小Ho你会下国际象棋么? 小Ho:应该算会吧,我知道每个棋子的移动方式,马走日象 ...

  2. 【hihocoder 1308】搜索二·骑士问题

    [题目链接]:http://hihocoder.com/problemset/problem/1308 [题意] [题解] 用bfs处理出3个骑士到每个点的最短路; 然后枚举最后3个骑士到了哪一个点. ...

  3. hihoCoder 1308:搜索二·骑士问题(BFS预处理)

    题目链接 题意 中文题意. 思路 对于每一个骑士,可以先预处理出到达地图上某个点的需要走的步数,然后最后暴力枚举地图上每一个点,让三个骑士走过的距离之和最小即可. #include <bits/ ...

  4. lintcode:搜索二维矩阵II

    题目 搜索二维矩阵 II 写出一个高效的算法来搜索m×n矩阵中的值,返回这个值出现的次数. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每一列的整数从上到下是排序的. 在每一行或每一列中没 ...

  5. lintcode :搜索二维矩阵

    题目: 搜索二维矩阵 写出一个高效的算法来搜索 m × n矩阵中的值. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每行的第一个数大于上一行的最后一个整数. 样例 考虑下列矩阵: [ [1 ...

  6. 算法进阶面试题05——树形dp解决步骤、返回最大搜索二叉子树的大小、二叉树最远两节点的距离、晚会最大活跃度、手撕缓存结构LRU

    接着第四课的内容,加入部分第五课的内容,主要介绍树形dp和LRU 第一题: 给定一棵二叉树的头节点head,请返回最大搜索二叉子树的大小 二叉树的套路 统一处理逻辑:假设以每个节点为头的这棵树,他的最 ...

  7. LintCode-38.搜索二维矩阵 II

    搜索二维矩阵 II 写出一个高效的算法来搜索m×n矩阵中的值,返回这个值出现的次数. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每一列的整数从上到下是排序的. 在每一行或每一列中没有重复 ...

  8. LeetCode74.搜索二维矩阵

    74.搜索二维矩阵 描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的最后一个整数. 示例 示 ...

  9. LeetCode:搜索二维矩阵【74】

    LeetCode:搜索二维矩阵[74] 题目描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的 ...

随机推荐

  1. vue - 前置工作 - 目录功能介绍

    一个DEMOS的完整目录(由于GWF问题,我就不一一打开网站一个个去搜索并且解释了)可以去关注:https://www.cnblogs.com/ye-hcj build build.js(本文来自ht ...

  2. 消息列队 分布式事务解办法 celery flower使用总结

    前言 项目中有场景 需要用到 分布式事务业务,经过查下资料把学习相关笔记做记录方便他人或者自己后面查看. 场景 在网站A业务中有个操作 是 要在网站B中新建一台服务器跑业务.A中执行B中的接口创建服务 ...

  3. 【转载】关于Hash

    这个HASH算法不是大学里数据结构课里那个HASH表的算法.这里的HASH算法是密码学的基础,比较常用的有MD5和SHA,最重要的两条性质,就是不可逆和无冲突.所谓不可逆,就是当你知道x的HASH值, ...

  4. 为什么说JAVA中要慎重使用继承 C# 语言历史版本特性(C# 1.0到C# 8.0汇总) SQL Server事务 事务日志 SQL Server 锁详解 软件架构之 23种设计模式 Oracle与Sqlserver:Order by NULL值介绍 asp.net MVC漏油配置总结

    为什么说JAVA中要慎重使用继承   这篇文章的主题并非鼓励不使用继承,而是仅从使用继承带来的问题出发,讨论继承机制不太好的地方,从而在使用时慎重选择,避开可能遇到的坑. JAVA中使用到继承就会有两 ...

  5. v-for指令

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. W5500EVB TCP Server演示

    之前给大家展示了p=6471" style="margin:0px; padding:0px; border:0px; font-family:inherit; font-size ...

  7. hadoop eclipse插件生成

    hadoop eclipse插件生成 做了一年的hadoop开发.还没有自动生成过eclipse插件,一直都是在网上下载别人的用,今天有时间,就把这段遗憾补回来,自己生成一下,废话不说,開始了. 本文 ...

  8. Codeforces Round #426 (Div. 2) D. The Bakery 线段树优化DP

    D. The Bakery   Some time ago Slastyona the Sweetmaid decided to open her own bakery! She bought req ...

  9. Space for commit to queue couldn't be acquired

    18/07/27 16:53:53 ERROR source.ExecSource: Failed while running command: tail -F /home/MyBgJavaLan/p ...

  10. Do not use the <section> element as a generic container; this is what <div> is for, especially when the sectioning is only for styling purposes.

    Do not use the <section> element as a generic container; this is what <div> is for, espe ...