Re: [闲聊] 每日LeetCode

楼主: oin1104 (是oin的说)   2024-01-28 17:05:05
今天是问 在一个2d的阵列里面
有多少个子阵列加起来==target
我用prefix sum做的
然后我刚刚看
好像可以用hashmap加上去做
好扯喔
class Solution {
public:
int numSubmatrixSumTarget(vector<vector<int>>& matrix, int target)
{
int ans = 0;
vector<vector<int>> summat ;
summat = matrix;
int n = matrix[0].size();
int m = matrix.size();
for(int i = 1 ; i < n ; i ++)
{
summat[0][i] += summat[0][i-1];
}
for(int i = 1 ; i < m ; i ++)
{
summat[i][0] += summat[i-1][0];
}
for(int i = 1 ; i < m ; i ++)
{
for(int j = 1 ; j < n ; j ++)
{
summat[i][j] = summat[i][j] + summat[i-1][j] + summat[i][j-1] -
summat[i-1][j-1];
}
}
for(int na = 0 ; na < n ; na ++)
{
for(int ma = 0 ; ma < m ; ma ++)
{
for(int nb = na ; nb < n ; nb ++)
{
for(int mb = ma ; mb < m ; mb ++)
{
int k = 0 ;
if((na > 0)&&(ma > 0))
{
k = summat[mb][nb] - summat[mb][na-1] - summat[ma-1]
[nb] + summat[ma-1][na-1];
}
else if(na > 0)
{
k = summat[mb][nb] - summat[mb][na-1] ;
}
else if(ma > 0)
{
k = summat[mb][nb] - summat[ma-1][nb] ;
}
else
{
k = summat[mb][nb] ;
}
if(k == target) ans ++;
}
}
}
}
return ans;
}
};
作者: wu10200512 (廷廷)   2024-01-28 17:06:00
==4层循环也能过ㄛ 好狠
楼主: oin1104 (是oin的说)   2024-01-28 17:06:00
= =对ㄚ 好爽而且我还beat 66% 其他人是在干三小好像是因为这个才100*100 所以顶多10000*10000 稳的
作者: SecondRun (雨夜琴声)   2024-01-28 17:14:00
大师

Links booklink

Contact Us: admin [ a t ] ucptt.com