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)位置的概率。

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

相关推荐
Cl_rown去掉l变成C7 分钟前
第J3-1周:DenseNet算法 实现乳腺癌识别
人工智能·pytorch·算法
努力学习的小廉7 分钟前
我爱学算法之—— 前缀和(中)
开发语言·redis·算法
保持学习ing9 分钟前
黑马Java面试笔记之 集合篇(算法复杂度+ArrayList+LinkedList)
java·笔记·算法·面试
LunaGeeking13 分钟前
三分算法与DeepSeek辅助证明是单峰函数
c语言·c++·算法·编程·信奥赛·ai辅助学习·三分
想带你从多云到转晴32 分钟前
02. java: 类与对象
java·开发语言
abments1 小时前
基于ReAction范式的问答系统实现demo
开发语言·python
Darkwanderor1 小时前
数论——同余问题全家桶3 __int128和同余方程组
c++·算法·数论·中国剩余定理
Xyz_Overlord1 小时前
机器学习——聚类算法
算法·机器学习·聚类
dessler1 小时前
代理服务器-LVS的3种模式与调度算法
运维·服务器·网络·算法·nginx·tomcat·lvs
拼好饭和她皆失1 小时前
动态规划 熟悉30题 ---上
算法·动态规划