一个很直观的想法是,求出每个点上下左右能到达的最大长度。然后枚举其斜边。。。没想到过了。。。。

当然,题解有一个很巧妙的优化,利用树状数组,那个太巧妙了。

#include<iostream>
#include<cmath>
#include<cstdio>
#include<vector>
#include<cstring>
#include<algorithm>
using namespace std; int t,T,ans,s[1005][1005],n;
int d1[1005][1005],d2[1005][1005],dt[1005][1005],dd[1005][1005],dl[1005][1005],dr[1005][1005];
//dt(top) dd(down) dl(left) dr(right)表示该点向四个方向最长有几个1
//d1表示该点向右下对角线的最长边长(即该点向下和向右短的那条边) d2表示向左上
int main()
{
int i,j,k;
scanf("%d",&T);
t=0;
while(T--)
{
ans=0;
t++;
scanf("%d",&n);
for(i=0;i<n;i++)
for(j=0;j<n;j++)
{
scanf("%d",&s[i][j]);
if(s[i][j]) ans++;
}
memset(dt,0,sizeof dt);
memset(dd,0,sizeof dd);
memset(dr,0,sizeof dr);
memset(dl,0,sizeof dl);
for(i=0;i<n;i++)//右下方向
{
for(j=0;j<n;j++)
{
if(s[i][j])
{
dd[i][j]=dd[i-1][j]+1;
dr[i][j]=dr[i][j-1]+1;
}
d1[i][j]=min(dd[i][j],dr[i][j]);
}
}
for(i=n-1;i>=0;i--)//左上方向
{
for(j=n-1;j>=0;j--)
{
if(s[i][j])
{
dt[i][j]=dt[i+1][j]+1;
dl[i][j]=dl[i][j+1]+1;
}
d2[i][j]=min(dt[i][j],dl[i][j]);
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
for(k=2;k<=d2[i][j];k++)//枚举边长
{
if(k<=d1[i+k-1][j+k-1])
ans++;
}
}
}
printf("Case %d: %d\n",t,ans);
}
return 0;
}

  

最新文章

  1. usb驱动开发24之接口驱动
  2. FreeBSD network connect
  3. 别再迷信 zepto 了
  4. Node.js 手册查询-1-核心模块方法
  5. EB-SAM9G45裸机程序下载方法
  6. windows batch语法
  7. 前端网址收集!Amazing! 神奇!
  8. [BS-11] 关于RGB/ARGB颜色相关知识
  9. Linux驱动设计——字符杂项设备
  10. jQuery实现的鼠标滑过切换图片代码实例
  11. Codeforces Round #368 (Div. 2) C. Pythagorean Triples(数学)
  12. 通过javascript库JQuery实现页面跳转功能代码
  13. c语言,动态数组
  14. JavaEE(13) - JPA属性映射
  15. github not authorized eclipse 关于 代码不能提交到GitHub
  16. linux线程 join/detach
  17. ExtJs写本地ArrayStore,ComboBox调用
  18. USG防火墙DHCP设置保留IP地址
  19. VS Code折腾记 - (4) 常用必备插件推荐【前端】
  20. BZOJ.1396.识别子串(后缀自动机/后缀数组 线段树)

热门文章

  1. [ASP.NET]EF选一个空表的情况
  2. HDU 1874 畅通project续 (最短路径)
  3. codeforces 490 D Chocolate
  4. 0x01 位运算
  5. bzoj3998: [TJOI2015]弦论(SAM+dfs)
  6. c语言实现皇帝翻牌游戏
  7. Java悲观锁和乐观锁
  8. ROS-Gazebo文件标签解读
  9. C# web api 中过滤器的使用
  10. HDU 3830 Checkers(二分+lca)