日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

6203. 矩阵中和能被 K 整除的路径(每日一难phase2--day29)

發(fā)布時間:2024/3/26 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 6203. 矩阵中和能被 K 整除的路径(每日一难phase2--day29) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

6203. 矩陣中和能被 K 整除的路徑

給你一個下標從 0 開始的 m x n 整數(shù)矩陣 grid 和一個整數(shù) k 。你從起點 (0, 0) 出發(fā),每一步只能往 下 或者往 右 ,你想要到達終點 (m - 1, n - 1) 。

請你返回路徑和能被 k 整除的路徑數(shù)目,由于答案可能很大,返回答案對 109 + 7 取余 的結(jié)果。

示例 1:

輸入:grid = [[5,2,4],[3,0,5],[0,7,2]], k = 3
輸出:2
解釋:有兩條路徑滿足路徑上元素的和能被 k整除。
第一條路徑為上圖中用紅色標注的路徑,和為 5 + 2 + 4 + 5 + 2 = 18 ,能被 3 整除。
第二條路徑為上圖中用藍色標注的路徑,和為 5 + 3 + 0 + 5 + 2 = 15 ,能被 3 整除。

示例 2:

輸入:grid = [[0,0]], k = 5
輸出:1
解釋:紅色標注的路徑和為 0 + 0 = 0 ,能被 5 整除。

示例 3:

輸入:grid = [[7,3,4,9],[2,3,6,2],[2,3,7,0]], k = 1
輸出:10
解釋:每個數(shù)字都能被 1 整除,所以每一條路徑的和都能被 k 整除。

提示:

m == grid.length
n == grid[i].length
1 <= m, n <= 5 * 1e4
1 <= m * n<= 5 * 1e4
0 <= grid[i][j] <= 100
1 <= k <= 50

解析:

  • 方法1暴力遞歸
  • 方法2,記憶化搜索
  • 方法3,動態(tài)規(guī)劃(從左上到右下,從右下到左上)
  • 動態(tài)規(guī)劃:選擇從右下到左上,f[x][y][l]表示,第x行,y列提供余數(shù)為 l 的路徑個數(shù);
  • 狀態(tài)轉(zhuǎn)移 : f[x][y][tmp] = ((long long)f[x+1][y][l]+f[x][y+1][l])%mod;
  • 左方和下方,提供余數(shù)為l時,第x行,y列余數(shù)為 tmp (tmp=(l+grid[x][y])%k) 時的路徑個數(shù).
  • f[0][0][0]表示第0行,0列余數(shù)為 0時,路徑個數(shù)(也就是路徑總和%k為0)。

代碼:

/* // 記憶化搜索,數(shù)組運用不當過不了 class Solution {int mod=1e9+7; public:int m,n;int dfs(vector<vector<int>>& grid, int k,int x,int y,int sum,vector<vector<vector<int>>>& f){if(f[x][y][sum])return f[x][y][sum];if(x==m-1&&y==n-1){if((sum+grid[x][y])%k==0)return 1;else return 0;}int tmp=sum;sum+=grid[x][y];sum%=k;int a=0, b=0;if(x+1<m)a = dfs(grid,k,x+1,y,sum,f);if(y+1<n)b = dfs(grid,k,x,y+1,sum,f);// cout<<a<<":"<<b<<endl;f[x][y][tmp] = ((long long)a+b)%mod;return f[x][y][tmp];}int numberOfPaths(vector<vector<int>>& grid, int k) {m=grid.size(),n=grid[0].size();vector<vector<vector<int>>> f(m+1,vector<vector<int>>(n+1,vector<int>(k+1,0)));return dfs(grid,k,0,0,0,f);} }; */class Solution {int mod=1e9+7; public:int numberOfPaths(vector<vector<int>>& grid, int k) {int m=grid.size(),n=grid[0].size();int f[m+1][n+1][k+1];memset(f,0,sizeof(f));// f[x][y][l]表示當前層grid[x][y]提供數(shù)字為l時,可以提供的路徑最大數(shù)f[m-1][n-1][grid[m-1][n-1]%k]=1;for(int x=m-1;x>=0;x--){for(int y=n-1;y>=0;y--){// 遍歷右側(cè),下側(cè)可以提供余數(shù)lfor(int l=0;l<k;l++){// 最后一個元素只能提供余數(shù)為grid[m-1][n-1]%k的路徑// 防止賦值被覆蓋if(x==m-1&&y==n-1)break;int tmp = grid[x][y]%k;tmp+=l;tmp%=k;// 右側(cè),下側(cè)可以提供余數(shù)l時,加上該數(shù)字可以產(chǎn)生的余數(shù)為tmp// 如果不考慮余數(shù),當作真實數(shù)字更好理解點f[x][y][tmp] = ((long long)f[x+1][y][l]+f[x][y+1][l])%mod;}}}return f[0][0][0];} };

總結(jié)

以上是生活随笔為你收集整理的6203. 矩阵中和能被 K 整除的路径(每日一难phase2--day29)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。