Leetcode 935 Knight Dialer
A chess knight can move as indicated in the chess diagram below:
.
This time, we place our chess knight on any numbered key of a phone pad (indicated above), and the knight makes N-1
hops. Each hop must be from one key to another numbered key.
Each time it lands on a key (including the initial placement of the knight), it presses the number of that key, pressing digits N
total.
How many distinct numbers can you dial in this manner?
Since the answer may be large, output the answer modulo 10^9 + 7
.
Example 1:
Input: 1 Output: 10
Example 2:
Input: 2 Output: 20
Example 3:
Input: 3 Output: 46
Note:
1 <= N <= 5000
這個題的意思是根據一個騎士的遊歷表,輸入的是要產生的電話位數,使用dp來解即可。
1)
class Solution {
const int MOD = 1e9+7;
int add(int a, int b) { return (a + b) % MOD; }
public:
int knightDialer(int N) {
int dp[5111][10];
for(int i=0;i<10;i++) dp[0][i] = 1;
for(int t=1;t<N;t++) {
dp[t][0] = add(dp[t-1][4], dp[t-1][6]);
dp[t][1] = add(dp[t-1][6], dp[t-1][8]);
dp[t][2] = add(dp[t-1][7], dp[t-1][9]);
dp[t][3] = add(dp[t-1][4], dp[t-1][8]);
dp[t][4] = add(dp[t-1][0], add(dp[t-1][9], dp[t-1][3]));
dp[t][5] = 0;
dp[t][6] = add(dp[t-1][1], add(dp[t-1][7], dp[t-1][0]));
dp[t][7] = add(dp[t-1][2], dp[t-1][6]);
dp[t][8] = add(dp[t-1][1], dp[t-1][3]);
dp[t][9] = add(dp[t-1][2], dp[t-1][4]);
}
int ans = 0;
for(int i=0;i<10;i++) ans = add(ans, dp[N-1][i]);
return ans;
}
};
2)
public static final int MOD = 1000000007;
public int knightDialer(int N) {
int[][] graph = new int[][]{{4,6},{6,8},{7,9},{4,8},{3,9,0},{},{1,7,0},{2,6},{1,3},{2,4}};
int cnt = 0;
Integer[][] memo = new Integer[N+1][10];
for (int i = 0; i <= 9; i++)
cnt = (cnt + helper(N-1, i, graph, memo)) % MOD;
return cnt;
}
private int helper(int N, int cur, int[][] graph, Integer[][] memo) {
if (N == 0)
return 1;
if (memo[N][cur] != null)
return memo[N][cur];
int cnt = 0;
for (int nei : graph[cur])
cnt = (cnt + helper(N-1, nei, graph, memo)) % MOD;
memo[N][cur] = cnt;
return cnt;
}
相關文章
- 4.4Codeforces Round 935 (Div. 3)
- Knight Frank:2020財富報告
- Knight Frank:2024年財富報告
- Knight Frank:2023年財富報告
- 2018 年年終總結 - J_Knight_
- Dragon_Knight_CTF-stack(棧遷移)Go
- Knight Frank:2022年財富報告
- Knight Frank:2021年財富報告
- Knight Frank:2022年滑雪物業報告
- Knight Frank:2020年印度零售報告
- Knight Frank:2022年英國城市主題報告
- 重溫一下經典-霹靂遊俠 Knight RiderIDE
- Knight Frank:2022年全球房地產投資趨勢報告
- 技嘉打造特色MOD主機,助力Knight9突破電競極限
- Counterpoint:2023年全球Top 5 晶圓廠裝置 (WFE) 製造商營收 935 億美元營收
- Newzoo:2023年全球PC和主機遊戲消費支出增長2.6% 達935億美元遊戲
- 我從寫技術部落格中收穫到了什麼?- J_Knight_
- 【LeetCode】如何學習LeetCode?LeetCode
- Gallup/Knight :美國成年人認為紙媒報導假新聞佔39%
- leetcodeLeetCode
- LeetCode in actionLeetCode
- leetcode 238LeetCode
- LeetCode 164 最大間距 HERODING的LeetCode之路LeetCode
- LeetCode 143 重排連結串列 HERODING的LeetCode之路LeetCode
- LeetCode問題LeetCode
- 【LeetCode】Jewels and StonesLeetCode
- Leetcode 513 javascriptLeetCodeJavaScript
- LeetCode 162 JavascriptLeetCodeJavaScript
- Leetcode 921 JavascriptLeetCodeJavaScript
- [Leetcode] Edit DistanceLeetCode
- LeetCode 克隆圖LeetCode
- LeetCode #378 JavaScriptLeetCodeJavaScript
- LeetCode 747 JavaScriptLeetCodeJavaScript
- Leetcode725LeetCode
- LeetCode 53 JSLeetCodeJS
- LeetCode 50 JSLeetCodeJS
- Leetcode03LeetCode
- LeetCode 799 JavaScriptLeetCodeJavaScript