C ++中的矩阵块总和
假设我们有一个名为mat的m*n矩阵和一个整数K,我们必须找到另一个矩阵答案,其中每个答案[i][j]是i-K<=的所有元素mat[r][c]的总和r<=i+K,j-K<=c<=j+K,并且(r,c)是矩阵中的有效位置。所以如果输入像-
且k为1,则输出为-
为了解决这个问题,我们将遵循以下步骤-
n:=行数,m=列数
定义一个矩阵ans,其顺序为nxm
对于i,范围为0至n–1
对于在i–k到i+k范围内的r
如果r和c在矩阵索引内,则
ans[i,j]:=ans[i,j]+mat[r,c]
对于范围j–k至j+k的c
对于j,范围从0到m–1
返回ans
例子(C++)
让我们看下面的实现以更好地理解-
#include <bits/stdc++.h>
using namespace std;
void print_vector(vector<vector<auto> > v){
cout << "[";
for(int i = 0; i<v.size(); i++){
cout << "[";
for(int j = 0; j <v[i].size(); j++){
cout << v[i][j] << ", ";
}
cout << "],";
}
cout << "]"<<endl;
}
class Solution {
public:
vector<vector<int>> matrixBlockSum(vector<vector<int>>& mat, int k) {
int n = mat.size();
int m = mat[0].size();
vector < vector <int> > ans(n , vector <int> (m));
for(int i = 0; i < n; i++){
for(int j = 0; j < m; j++){
for(int r = i - k;r <= i + k; r++){
for(int c = j - k; c <= j + k; c++){
if(r>= 0 && r < n && c >= 0 && c < m){
ans[i][j] += mat[r][c];
}
}
}
}
}
return ans;
}
};
main(){
vector<vector<int>> v1 = {{1,2,3},{4,5,6},{7,8,9}};
Solution ob;
print_vector(ob.matrixBlockSum(v1, 1));
}输入值
[[1,2,3],[4,5,6],[7,8,9]] 1
输出结果
[[12, 21, 16, ],[27, 45, 33, ],[24, 39, 28, ],]