本文共 583 字,大约阅读时间需要 1 分钟。
题目描述
帕秋莉掌握了一种土属性魔法 这种魔法可以在一片k×k大小的一个正方形区域内产生地震 但是如果某片即将产生地震的区域内有建筑物,帕秋莉会停止施法 整个地图大小为n×m,其中一些地方有建筑 请问有多少种可能的情况,使得帕秋莉会停止施法输入描述:
第一行三个数n, m, k,意义见描述
接下来一个n×m的01矩阵表示这篇区域的情况,1表示这个地方有建筑输出描述:
输出一个数表示答案
输入
4 4 2
1000 0100 0000 0001输出
5
思路:算法核心:前缀和
本质最大子矩阵求大于0 的矩阵数量,详细解法见 直接上代码(//土 秘法地震 //算法:前缀和 //本质:最大子矩阵,再本质:最大连续子串 #includeusing namespace std;typedef long long ll;int a[1005][1005];//矩阵 int main(){ int i,j,k,n,m,cnt=0;//cnt计数符合情况的数量 string str; cin>>n>>m>>k; for(i=1;i<=n;i++) { cin>>str; for(j=0;j 0) cnt++;//符合情况 cout< <
转载地址:http://rsxwz.baihongyu.com/