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

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

相关推荐
weifexie33 分钟前
ruby可变参数
开发语言·前端·ruby
王磊鑫34 分钟前
重返JAVA之路-初识JAVA
java·开发语言
千野竹之卫34 分钟前
3D珠宝渲染用什么软件比较好?渲染100邀请码1a12
开发语言·前端·javascript·3d·3dsmax
liuluyang5302 小时前
C语言C11支持的结构体嵌套的用法
c语言·开发语言·算法·编译·c11
凌叁儿2 小时前
python保留关键字详解
开发语言·python
明飞19872 小时前
C_内存 内存地址概念
c语言·开发语言
勤劳的进取家3 小时前
贪心算法之最小生成树问题
数据结构·python·算法·贪心算法·排序算法·动态规划
代码不停3 小时前
Java中的异常
java·开发语言
牛奶咖啡.8543 小时前
第十四届蓝桥杯大赛软件赛省赛C/C++ 大学 A 组真题
c语言·数据结构·c++·算法·蓝桥杯
兮兮能吃能睡3 小时前
Python中的eval()函数详解
开发语言·python