Yes the accu* is not necessary :)
class NumMatrix { vector<vector<int>> dp; public: NumMatrix(vector<vector<int>> &matrix) { int h = matrix.size(); if(!h) return; int w = matrix[0].size(); vector<vector<int>> accuCols(h, vector<int>(w)); vector<vector<int>> accuRows(h, vector<int>(w)); // Accumulated Col sums for(int i = 0; i < w; i ++) { accuCols[0][i] = matrix[0][i]; for(int j = 1; j < h; j ++) { accuCols[j][i] = accuCols[j - 1][i] + matrix[j][i]; } } // Accumulated Row sums for(int j = 0; j < h; j ++) { accuRows[j][0] = matrix[j][0]; for(int i = 1; i < w; i ++) { accuRows[j][i] = accuRows[j][i - 1] + matrix[j][i]; } } dp.assign(h + 1, vector<int>(w + 1, 0)); for(int i = 0; i < h; i ++) for(int j = 0; j < w; j ++) { dp[i + 1][j + 1] = dp[i][j] + accuCols[i][j] + accuRows[i][j] - matrix[i][j]; } } int sumRegion(int row1, int col1, int row2, int col2) { int v = dp[row2 + 1][col2 + 1] - dp[row1][col1]; int u = dp[row1][col2 + 1] - dp[row1][col1]; int l = dp[row2 + 1][col1] - dp[row1][col1]; return v - u - l; } };
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步