【LeetCode】909. 蛇梯棋

简介: 【LeetCode】909. 蛇梯棋

题目链接

909. 蛇梯棋

题目简介

N x N 的棋盘 board 上,按从 1 到 N*N 的数字给方格编号,编号 从左下角开始,每一行交替方向。

例如,一块 6 x 6 大小的棋盘,编号如下:

r 行 c 列的棋盘,按前述方法编号,棋盘格中可能存在 “蛇” 或 “梯子”;如果 board[r][c] != -1,那个蛇或梯子的目的地将会是 board[r][c]。

玩家从棋盘上的方格 1 (总是在最后一行、第一列)开始出发。

每一回合,玩家需要从当前方格 x 开始出发,按下述要求前进:

  • 选定目标方格:选择从编号 x+1,x+2,x+3,x+4,x+5,或者 x+6 的方格中选出一个目标方格 s ,目标方格的编号 <= N*N。
  • 该选择模拟了掷骰子的情景,无论棋盘大小如何,你的目的地范围也只能处于区间 [x+1, x+6] 之间。
  • 传送玩家:如果目标方格 S 处存在蛇或梯子,那么玩家会传送到蛇或梯子的目的地。否则,玩家传送到目标方格 S。
  • 注意,玩家在每回合的前进过程中最多只能爬过蛇或梯子一次:就算目的地是另一条蛇或梯子的起点,你也不会继续移动。

返回达到方格 N*N 所需的最少移动次数,如果不可能,则返回 -1。

示例:

输入:[
[-1,-1,-1,-1,-1,-1],
[-1,-1,-1,-1,-1,-1],
[-1,-1,-1,-1,-1,-1],
[-1,35,-1,-1,13,-1],
[-1,-1,-1,-1,-1,-1],
[-1,15,-1,-1,-1,-1]]
输出:4
解释:
首先,从方格 1 [第 5 行,第 0 列] 开始。
你决定移动到方格 2,并必须爬过梯子移动到到方格 15。
然后你决定移动到方格 17 [第 3 行,第 5 列],必须爬过蛇到方格 13。
然后你决定移动到方格 14,且必须通过梯子移动到方格 35。
然后你决定移动到方格 36, 游戏结束。
可以证明你需要至少 4 次移动才能到达第 N*N 个方格,所以答案是 4。

提示:

  • 2 <= board.length = board[0].length <= 20
  • board[i][j] 介于 1 和 N*N 之间或者等于 -1。
  • 编号为 1 的方格上没有蛇或梯子。
  • 编号为 N*N 的方格上没有蛇或梯子。

题目解析

  1. 1。这个翻译真是一言难尽,实在 啥也看不懂~
  2. 2.简单来说:给你一个图,图上每个点有自己的编号ID(蛇形分布),从 1 ~ n * n,每一次你最多能走1~6个点(骰子),当你走到的点的数值不为 -1 时,则可以触发传送机制 (一次操作只能触发一次传送),直接传送至该数值的点。比如你扔骰子到第二个点,第二个点的数值为8,可直接传送至第八个点。当然,每一个点只能走一次。
  1. 3.使用BFS(广度优先搜索)
  • 首先,我们将第一个点放置队列,
  • ,由题意我们可知,我们还需要将当前移动的次数放置,队列中存放为:queue.offer(new int[]{1,0};)
  • 我们进入第一轮的骰子,可以推断中,第一轮我们可以走过的点数为:2 ~ 7,我们还需要检查下 2 ~ 7 是否可以触发传送机制,
  • 这样我们就可以尽量的走远。
  • 因为我们传送的编号ID,所以我们需要通过该 ID 找到 ID 所在的下标
  • 最后如果可以到达 n * n,返回次数,否则,return -1

题目代码

class Solution {
    public int snakesAndLadders(int[][] board) {
        Queue<int[]> queue = new LinkedList<>();
        int n = board.length;
        boolean[] vis = new boolean[n * n + 1];
        // 在第一个坐标,移动0个距离
        queue.offer(new int[]{1, 0});
        while(!queue.isEmpty()){
            int[] p = queue.poll();
            for(int i = 1; i <= 6; i++){
              // 骰子可以移动的点数
                int cnt = p[0] + i;
                // 当前点数大于矩阵的最大点数
                if(cnt > n * n){
                    break;
                }
        // 得到该点数的坐标值
                int[] rc = id2rc(cnt, n);
                // 判断这是否是个梯子,可以传送
                if(board[rc[0]][rc[1]] > 0){
                  // 是的话,可以直接进行传送操作
                    cnt = board[rc[0]][rc[1]];
                }
        // 正好到达终点
                if(cnt == n * n){
                    return p[1] + 1;
                }
                // 该点没有被遍历过
                if(!vis[cnt]){
                    vis[cnt] = true;
                    queue.offer(new int[]{cnt, p[1] + 1});
                }
            }
        }
        return
    }
    public int[] id2rc(int id, int n){
        int r = (id - 1) / n;
        int c = (id - 1) % n;
        if(r % 2 == 0){
            c = n - 1 - c;
        }
        return new int[]{n - 1 - r, c};
    }
}
相关文章
|
C++
UE4/5中DataTable数据表的使用
UE4/5中DataTable数据表的使用
1390 1
UE4/5中DataTable数据表的使用
|
Prometheus 负载均衡 监控
详解Gateway
详解Gateway
1903 0
|
安全 项目管理
一文搞懂需求流程规范的制定方法和落地技巧
随着业务和产品的发展、团队的不断扩大,很多团队都不可避免的会遇到需求流程混乱的问题。虽然有的团队也编写了一些“需求流程规范”的文档,但最终却流于纸面,难以在团队真正落地。如何科学制定并有效落实需求管理规范呢?对此,云效产品经理陈逊进行了非常详细的直播分享,本文是他经验的文字总结。
103576 19
|
项目管理 开发者 Windows
【KiCad镜像】下载与安装
KiCad EDA 是一款用于印刷电路板设计的开源自由软件,基于 GPLv3 开源协议。 软件包含工程项目管理、原理图设计、线路板绘制、符号库设计、封装库设计、线路板 3D 显示、Gerber 查看、线路板实用计算等工具。
931 0
|
算法 调度 芯片
NR CSI(二) the workflow of CSI report
本篇内容是对CSI report相关流程的整理,其描述主要集中在R16 38.331 38.321 38.214中,以实网中的一个配置开始,看下相关定义。
|
Ubuntu Python
Ubuntu安装pip并切换国内源
Ubuntu安装pip并切换国内源
3912 0
Ubuntu安装pip并切换国内源
|
3月前
|
SQL 缓存 安全
深度理解 Java 内存模型:从并发基石到实践应用
本文深入解析 Java 内存模型(JMM),涵盖其在并发编程中的核心作用与实践应用。内容包括 JMM 解决的可见性、原子性和有序性问题,线程与内存的交互机制,volatile、synchronized 和 happens-before 等关键机制的使用,以及在单例模式、线程通信等场景中的实战案例。同时,还介绍了常见并发 Bug 的排查与解决方案,帮助开发者写出高效、线程安全的 Java 程序。
168 0
|
11月前
|
存储 前端开发 JavaScript
如何在项目中高效地进行 Web 组件化开发
高效地进行 Web 组件化开发需要从多个方面入手,通过明确目标、合理规划、规范开发、加强测试等一系列措施,实现组件的高效管理和利用,从而提高项目的整体开发效率和质量,为用户提供更好的体验。
330 63
WK
|
机器学习/深度学习 Java 程序员
为什么Python比C++慢很多?
Python相较于C++较慢主要体现在:动态类型系统导致运行时需解析类型,增加开销;作为解释型语言,逐行转换字节码的过程延长了执行时间;自动内存管理和垃圾回收机制虽简化操作但也带来了额外负担;全局解释器锁(GIL)限制了多线程性能;尽管Python库方便灵活,但在性能上往往不及C++底层库。然而,Python在某些领域如数据分析、机器学习中,凭借其高级别抽象和简洁语法仍表现出色。选语言需依据具体应用场景和需求综合考量。
WK
417 1
|
计算机视觉
cv2.putText
cv2.putText
807 1