前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 1197. 进击的骑士(BFS)

LeetCode 1197. 进击的骑士(BFS)

作者头像
Michael阿明
发布2021-02-19 10:49:12
8500
发布2021-02-19 10:49:12
举报
文章被收录于专栏:Michael阿明学习之路

文章目录

1. 题目

一个坐标可以从 -infinity 延伸到 +infinity 的 无限大的 棋盘上,你的 骑士 驻扎在坐标为 [0, 0] 的方格里。

骑士的走法和中国象棋中的马相似,走 “日” 字:即先向左(或右)走 1 格,再向上(或下)走 2 格;或先向左(或右)走 2 格,再向上(或下)走 1 格。

每次移动,他都可以按图示八个方向之一前进。

在这里插入图片描述
在这里插入图片描述

现在,骑士需要前去征服坐标为 [x, y] 的部落,请你为他规划路线。

最后返回所需的最小移动次数即可。本题确保答案是一定存在的。

代码语言:javascript
复制
示例 1:
输入:x = 2, y = 1
输出:1
解释:[0, 0] → [2, 1]

示例 2:
输入:x = 5, y = 5
输出:4
解释:[0, 0] → [2, 1] → [4, 2] → [3, 4] → [5, 5]
 
提示:
|x| + |y| <= 300

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/minimum-knight-moves 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

代码语言:javascript
复制
class Solution {
public:
    int minKnightMoves(int x, int y) {
    	vector<vector<int>> dir = {{2, 1},{2,-1},{-2,1},{-2,-1},{1,2},{1,-2},{-1,2},{-1,-2}};
    	x = abs(x), y = abs(y);//对称的,变成正的
    	int m = x+20, n = y+20;//放大一点
    	vector<vector<bool>> visited(m, vector<bool>(n,false));
    	x += 10, y += 10;//偏移10个单位,保证边界的上情况能够覆盖
    	queue<vector<int>> q;
    	q.push({10,10});//起点
    	visited[10][10] = true;
    	int step = 0, size, i, j, k, ni, nj;
    	while(!q.empty())
    	{
    		size = q.size();
    		while(size--)
    		{
    			i = q.front()[0];
    			j = q.front()[1];
    			if(i==x && j==y)
    				return step;
    			q.pop();
    			for(k = 0; k < 8; k++)
    			{
    				ni = i + dir[k][0];
    				nj = j + dir[k][1];
    				if(ni>=0 && ni<m && nj>=0 && nj<n && !visited[ni][nj])
    				{
    					q.push({ni,nj});
    					visited[ni][nj] = true;
    				}
    			}
    		}
    		step++;
    	}
    	return -1;
    }
};

296 ms 34.4 MB

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/08/04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 1. 题目
  • 2. 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档