骑士在棋盘上的概率(递归)

编程入门 行业动态 更新时间:2024-10-28 00:14:06

骑士在棋盘上的概率(<a href=https://www.elefans.com/category/jswz/34/1771140.html style=递归)"/>

骑士在棋盘上的概率(递归)

这道题使用递归思想虽然代码较简洁,但会出现大量的重复计算,但还是想把这种思路展示给大家:

class Solution {
public://vector<int> dirs = {{-2,1},{-1,2},{1,2},{2,1},{2,-1},{1,-2},{-1,-2},{-2,-1}};double knightProbability(int n, int k, int row, int column) {return (double)process(n, k, row, column)/pow(8,k);}long process(int n, int k, int row, int column){if(row<0||column<0||row>=n||column>=n){return 0;}if(k==0){return 1;}long d1 = process(n, k-1, row-2, column+1);long d2 = process(n, k-1, row-1, column+2);long d3 = process(n, k-1, row+1, column+2);long d4 = process(n, k-1, row+2, column+1);long d5 = process(n, k-1, row+2, column-1);long d6 = process(n, k-1, row+1, column-2);long d7 = process(n, k-1, row-1, column-2);long d8 = process(n, k-1, row-2, column-1);return d1 + d2 + d3 + d4 + d5 + d6 + d7 + d8;}
};

在n和k比较大的时候,栈会溢出,因此要转换思路使用动态规划求解,力扣上有官方题解,这里就不在重复了。

更多推荐

骑士在棋盘上的概率(递归)

本文发布于:2023-06-28 00:33:44,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/919129.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:递归   棋盘   概率   骑士

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!