Leecode刷题C语言之骑士在棋盘上的概率

执行结果:通过

执行用时和内存消耗如下:

代码如下:

复制代码
static int dirs[8][2]  = {{-2, -1}, {-2, 1}, {2, -1}, {2, 1}, {-1, -2}, {-1, 2}, {1, -2}, {1, 2}};

double knightProbability(int n, int k, int row, int column){
    double dp[200][30][30];
    memset(dp, 0, sizeof(dp));
    for (int step = 0; step <= k; step++) {
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < n; j++) {
                if (step == 0) {
                    dp[step][i][j] = 1.0;
                } else {
                    for (int k = 0; k < 8; k++) {
                        int ni = i + dirs[k][0], nj = j + dirs[k][1];
                        if (ni >= 0 && ni < n && nj >= 0 && nj < n) {
                            dp[step][i][j] += dp[step - 1][ni][nj] / 8;
                        }
                    }
                }
            }
        }
    }
    return dp[k][row][column];
}

解题思路:

  1. 定义方向数组
    • static int dirs[8][2] = {``{-2, -1}, {-2, 1}, {2, -1}, {2, 1}, {-1, -2}, {-1, 2}, {1, -2}, {1, 2}};
    • 这个数组定义了骑士每步可以移动的八个方向,分别是向上下左右以及四个对角线方向各移动两格和一格的组合。
  2. 函数定义
    • double knightProbability(int n, int k, int row, int column)
    • 这个函数接受四个参数:棋盘的大小n(假设棋盘是n x n的正方形),步数k,以及初始位置(row, column)
  3. 动态规划数组初始化
    • double dp[200][30][30];
    • memset(dp, 0, sizeof(dp));
    • 定义一个三维动态规划数组dp来存储每一步从每一个位置移动到其他位置的概率。数组的大小是根据题目限制预设的(假设棋盘大小不超过200x200)。
  4. 初始化基础情况
    • step == 0时,即骑士没有移动,位于初始位置(i, j)的概率是1.0。
    • dp[step][i][j] = 1.0;
  5. 状态转移
    • 对于每一步step(从1到k),遍历棋盘上的每一个位置(i, j)
    • 对于每一个位置,计算从上一个步数step-1的八个可能的前一个位置(ni, nj)移动到当前位置(i, j)的概率。
    • 由于骑士每步有八个等可能的移动方向,所以每个前一个位置(ni, nj)对当前位置(i, j)的贡献是dp[step - 1][ni][nj] / 8
    • 只有在(ni, nj)是有效位置(即在棋盘范围内)时,才计算这个贡献。
  6. 返回结果
    • 最后返回dp[k][row][column],即经过k步后,骑士位于(row, column)位置的概率。

总结来说,这段代码通过动态规划的方式,计算了骑士在给定步数内从初始位置移动到目标位置的概率。每一步都考虑了骑士从上一个位置通过八个方向移动到当前位置的所有可能性,并将这些可能性累加起来,最终得到目标位置的概率。

相关推荐
灵感__idea1 小时前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect11 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP1 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱1 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
祈安_1 天前
C语言内存函数
c语言·后端