935. Knight Dialer LeetCode Solution
In this guide, you will get 935. Knight Dialer LeetCode Solution with the best time and space complexity. The solution to Knight Dialer problem is provided in various programming languages like C++, Java, and Python. This will be helpful for you if you are preparing for placements, hackathons, interviews, or practice purposes. The solutions provided here are very easy to follow and include detailed explanations.
Table of Contents
- Problem Statement
- Complexity Analysis
- Knight Dialer solution in C++
- Knight Dialer solution in Java
- Knight Dialer solution in Python
- Additional Resources
data:image/s3,"s3://crabby-images/a7b7e/a7b7e2ac7dc69a4adc67d539c2bd8e3186ecae84" alt="935. Knight Dialer LeetCode Solution 935. Knight Dialer LeetCode Solution image"
Problem Statement of Knight Dialer
The chess knight has a unique movement, it may move two squares vertically and one square horizontally, or two squares horizontally and one square vertically (with both forming the shape of an L). The possible movements of chess knight are shown in this diagram:
A chess knight can move as indicated in the chess diagram below:
We have a chess knight and a phone pad as shown below, the knight can only stand on a numeric cell (i.e. blue cell).
Given an integer n, return how many distinct phone numbers of length n we can dial.
You are allowed to place the knight on any numeric cell initially and then you should perform n – 1 jumps to dial a number of length n. All jumps should be valid knight jumps.
As the answer may be very large, return the answer modulo 109 + 7.
Example 1:
Input: n = 1
Output: 10
Explanation: We need to dial a number of length 1, so placing the knight over any numeric cell of the 10 cells is sufficient.
Example 2:
Input: n = 2
Output: 20
Explanation: All the valid number we can dial are [04, 06, 16, 18, 27, 29, 34, 38, 40, 43, 49, 60, 61, 67, 72, 76, 81, 83, 92, 94]
Example 3:
Input: n = 3131
Output: 136006598
Explanation: Please take care of the mod.
Constraints:
1 <= n <= 5000
Complexity Analysis
- Time Complexity: O(n)
- Space Complexity: O(n)
935. Knight Dialer LeetCode Solution in C++
class Solution {
public:
int knightDialer(int n) {
constexpr int dirs[8][2] = {{1, 2}, {2, 1}, {2, -1}, {1, -2},
{-1, -2}, {-2, -1}, {-2, 1}, {-1, 2}};
constexpr int kMod = 1'000'000'007;
// dp[i][j] := the number of ways to stand on (i, j)
vector<vector<int>> dp(4, vector<int>(3, 1));
dp[3][0] = dp[3][2] = 0;
for (int k = 0; k < n - 1; ++k) {
vector<vector<int>> newDp(4, vector<int>(3));
for (int i = 0; i < 4; ++i)
for (int j = 0; j < 3; ++j) {
if (isNotNumericCell(i, j))
continue;
for (const auto& [dx, dy] : dirs) {
const int x = i + dx;
const int y = j + dy;
if (x < 0 || x >= 4 || y < 0 || y >= 3)
continue;
if (isNotNumericCell(x, y))
continue;
newDp[i][j] = (newDp[i][j] + dp[x][y]) % kMod;
}
}
dp = std::move(newDp);
}
int ans = 0;
for (const vector<int>& row : dp)
for (const int a : row)
ans = (ans + a) % kMod;
return ans;
}
private:
bool isNotNumericCell(int i, int j) {
return i == 3 && (j == 0 || j == 2);
}
};
/* code provided by PROGIEZ */
935. Knight Dialer LeetCode Solution in Java
class Solution {
public int knightDialer(int n) {
final int[][] dirs = {{1, 2}, {2, 1}, {2, -1}, {1, -2}, {-1, -2}, {-2, -1}, {-2, 1}, {-1, 2}};
final int kMod = 1_000_000_007;
// dp[i][j] := the number of ways to stand on (i, j)
int[][] dp = new int[4][3];
Arrays.stream(dp).forEach(A -> Arrays.fill(A, 1));
dp[3][0] = dp[3][2] = 0;
for (int k = 0; k < n - 1; ++k) {
int[][] newDp = new int[4][3];
for (int i = 0; i < 4; ++i)
for (int j = 0; j < 3; ++j) {
if (isNotNumericCell(i, j))
continue;
for (int[] dir : dirs) {
final int x = i + dir[0];
final int y = j + dir[1];
if (x < 0 || x >= 4 || y < 0 || y >= 3)
continue;
if (isNotNumericCell(x, y))
continue;
newDp[i][j] = (newDp[i][j] + dp[x][y]) % kMod;
}
}
dp = newDp;
}
int ans = 0;
for (int[] row : dp)
for (final int a : row)
ans = (ans + a) % kMod;
return ans;
}
private boolean isNotNumericCell(int i, int j) {
return i == 3 && (j == 0 || j == 2);
}
}
// code provided by PROGIEZ
935. Knight Dialer LeetCode Solution in Python
class Solution:
def knightDialer(self, n: int) -> int:
dirs = ((1, 2), (2, 1), (2, -1), (1, -2),
(-1, -2), (-2, -1), (-2, 1), (-1, 2))
kMod = 1_000_000_007
# dp[i][j] := the number of ways stand on (i, j)
dp = [[1] * 3 for _ in range(4)]
dp[3][0] = dp[3][2] = 0
for _ in range(n - 1):
newDp = [[0] * 3 for _ in range(4)]
for i in range(4):
for j in range(3):
if (i, j) in ((3, 0), (3, 2)):
continue
for dx, dy in dirs:
x = i + dx
y = j + dy
if x < 0 or x >= 4 or y < 0 or y >= 3:
continue
if (x, y) in ((3, 0), (3, 2)):
continue
newDp[x][y] = (newDp[x][y] + dp[i][j]) % kMod
dp = newDp
return sum(map(sum, dp)) % kMod
# code by PROGIEZ
Additional Resources
- Explore all LeetCode problem solutions at Progiez here
- Explore all problems on LeetCode website here
Happy Coding! Keep following PROGIEZ for more updates and solutions.