1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| class Solution { public: int d[8][2] = { {1, 2}, {2, 1}, {2, - 1}, {1, -2}, {-1, -2}, {-2, -1}, {-2, 1}, {-1, 2} }; double knightProbability(int N, int K, int r, int c) { if (K == 0) return 1.0; vector<vector<double> > dp(N, vector<double>(N, 1)); for (int k = 1; k <= K; ++k) { auto ans = dp; for (int i = 0; i < N; ++i) { for (int j = 0; j < N; ++j) { ans[i][j] = 0; for (int l = 0; l < 8; ++l) { int r = i + d[l][0]; int c = j + d[l][1]; if (r >= 0 && r < N && c >= 0 && c < N) { ans[i][j] += dp[r][c] / 8; } } } } swap(ans, dp); } return dp[r][c]; } };
|