题解 | #「土」秘法地震#

「土」秘法地震

https://ac.nowcoder.com/acm/problem/53676

题意 边长为k的小矩阵中不全为0的矩阵的个数
很明显 前缀和
然后枚举,以前一般从左上角开始枚举,要考虑边界情况,发现可以从右下角开始枚举可以不用考虑边界问题,学到了。

#include<iostream>
using namespace std;
int ans,n,m,r,a[1010][1010],sum[1010][1010];
char sb[1010][1010];
int main()
{
    cin>>n>>m>>r;
    for(int i=0;i<n;i++)
        cin>>sb[i];
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++)
            a[i+1][j+1]=sb[i][j]-'0';
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            sum[i][j]=sum[i-1][j]+sum[i][j-1]-sum[i-1][j-1]+a[i][j];
    for(int i=r;i<=n;i++)
        for(int j=r;j<=m;j++)
            if(sum[i][j]-sum[i-r][j]-sum[i][j-r]+sum[i-r][j-r])
                ans++;
    cout<<ans<<endl;
}
全部评论

相关推荐

27届毕业,最近想找一段大厂实习,感觉简历有些问题,好多都不给面,求大佬们指点,最近好焦虑
重生之我学Java干...:我从后端的角度分析一下你的第一个项目,我感觉亮点不是很突出。因为我是因为组内有需求,临时上手学react干活。我用到的技术基本就cover你那个智慧园区管理平台的很多亮点了。那作为比较专业的前端,你上述的内容是不是有点单薄呢。感觉还得包装
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务