题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1201

题意:

  有一个边长为n的正三角形网格,去掉其中一些线段,问你在这幅图中有多少个三角形。

题解:

  枚举 + 前缀和。

  三角形总共有两种:正着放的、倒着放的。

  分别处理就好。

  总复杂度 < O(N^3)

  为了判断某一个三角形是否存在,需要迅速判断它的三边是否都是实线(不断开)。

  所以建立三个前缀和,分别代表左、右、底边在对应方向上的边长和。

  若某一边上的区间和[a,b] == b-a+1,则为实线。

  如图为前缀和方向:

  

  正着放的:

    N^2枚举三角形最顶上的小三角形,再套一个for枚举向下延伸的边长k。

  

  倒着放的:

    倒三角形底部有一个小倒三角形,枚举它左边相邻的小正三角。

  

AC Code:

 #include <iostream>
#include <stdio.h>
#include <string.h>
#define MAX_N 1005 using namespace std; int n;
int ans=;
int l[MAX_N][MAX_N];
int r[MAX_N][MAX_N];
int b[MAX_N][MAX_N];
int lef[MAX_N][MAX_N];
int rig[MAX_N][MAX_N];
int btm[MAX_N][MAX_N]; void read()
{
memset(l,,sizeof(l));
memset(r,,sizeof(r));
memset(b,,sizeof(b));
cin>>n;
for(int i=;i<=n;i++)
{
for(int j=;j<=i;j++)
{
cin>>l[i][j]>>r[i][j]>>b[i][j];
}
}
} void cal_sum()
{
memset(lef,,sizeof(lef));
memset(rig,,sizeof(rig));
memset(btm,,sizeof(btm));
for(int i=;i<=n;i++)
{
for(int j=;j<=i;j++)
{
lef[i][j]=lef[i-][j]+l[i][j];
rig[i][j]=rig[i-][j-]+r[i][j];
btm[i][j]=btm[i][j-]+b[i][j];
}
}
} void find_tri()
{
for(int i=;i<=n;i++)
{
for(int j=;j<=i;j++)
{
for(int k=;;k++)
{
if(lef[i+k-][j]-lef[i-][j]<k) break;
if(rig[i+k-][j+k-]-rig[i-][j-]<k) break;
if(btm[i+k-][j+k-]-btm[i+k-][j-]<k) continue;
ans++;
}
}
}
for(int i=;i<=n;i++)
{
for(int j=;j<i;j++)
{
for(int k=;i-k>= && j-k>=;k++)
{
if(lef[i][j+]-lef[i-k][j+]<k) break;
if(rig[i][j]-rig[i-k][j-k]<k) break;
if(btm[i-k][j]-btm[i-k][j-k]<k) continue;
ans++;
}
}
}
} void solve()
{
cal_sum();
find_tri();
} void print()
{
cout<<ans<<endl;
} int main()
{
read();
solve();
print();
}

BZOJ 1201 [HNOI2005]数三角形:枚举 + 前缀和的更多相关文章

  1. bzoj 1201[HNOI2005]数三角形 1202 [HNOI2005]狡猾的商人 暴力 权值并查集

    [HNOI2005]数三角形 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 349  Solved: 234[Submit][Status][Disc ...

  2. 1201: [HNOI2005]数三角形 - BZOJ

    Description Input 大三角形的所有短边可以看成由(n+1)*n/2个单位三角形的边界组成.如下图的灰色三角形所示.其中第1排有1个灰色三角形,第2排有2个灰色三角形,……,第n排有n个 ...

  3. 【BZOJ1201】[HNOI2005]数三角形(暴力)

    [BZOJ1201][HNOI2005]数三角形(暴力) 题面 BZOJ 洛谷 题解 预处理每个点向四个方向可以拓展的最大长度,然后钦定一个点作为三角形的某个顶点,暴力枚举三角形长度,检查这样一个三角 ...

  4. BZOJ 3505: [Cqoi2014]数三角形 数学

    3505: [Cqoi2014]数三角形 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...

  5. Bzoj 3505: [Cqoi2014]数三角形 数论

    3505: [Cqoi2014]数三角形 Time Limits: 1000 ms  Memory Limits: 524288 KB  Detailed Limits   Description

  6. bzoj 3505: [Cqoi2014]数三角形 组合数学

    3505: [Cqoi2014]数三角形 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 478  Solved: 293[Submit][Status ...

  7. BZOJ 3505: [Cqoi2014]数三角形( 组合数 )

    先n++, m++ 显然答案就是C(3, n*m) - m*C(3, n) - n*C(3, m) - cnt. 表示在全部点中选出3个的方案减去不合法的, 同一行/列的不合法方案很好求, 对角线的不 ...

  8. BZOJ 3505: [Cqoi2014]数三角形 [组合计数]

    3505: [Cqoi2014]数三角形 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个. 注意三角形的三点不能共线. 1<=m,n<=1000 $n++ m++$ $ans ...

  9. BZOJ 3505 [Cqoi2014]数三角形

    3505: [Cqoi2014]数三角形 Description 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个.下图为4x4的网格上的一个三角形.注意三角形的三点不能共线. Input ...

随机推荐

  1. 【AngularJS】Yeoman安装

    看不到PPT的请自行解决DNS污染问题.

  2. 谷歌浏览器插件-html页面js事件查看器

    谷歌浏览器插件-html页面js事件查看器 1.下载 下载地址:http://files.cnblogs.com/files/graceup/VisualEvent.zip 解压得到文件:Visual ...

  3. C++中一些个函数的使用

    函数:sprintf的使用 函数功能:把格式化的数据写入某个字符串 函数原型:int sprintf( char *buffer, const char *format [, argument] … ...

  4. iOS多线程与网络开发之多线程概述

    郝萌主倾心贡献,尊重作者的劳动成果,请勿转载. 假设文章对您有所帮助,欢迎给作者捐赠.支持郝萌主,捐赠数额任意,重在心意^_^ 我要捐赠: 点击捐赠 Cocos2d-X源代码下载:点我传送 游戏官方下 ...

  5. linux下安装redis报错问题。

    1.使用tar -xzvf redis-2.4.5.tar.gz来解压安装包 2.使用make命令来编译Redis 如果出现错误需要查看是否缺少gcc gcc-c++ zmalloc.h:50:31: ...

  6. Visual Studio Code v1.17

    Visual Studio Code v1.17发布 欢迎来到2017年9月发行的Visual Studio代码.在这个版本中有一些重要的更新,我们希望你会喜欢,一些关键的亮点包括: macOS To ...

  7. mybatis前台传来一个String,后后台执行sql变成了true

    实际上参数传来的是一个字符串 3 ,不知道为什么会变成true 最后当然是查不到信息了.. 我在mapper映射文件里面使用了动态的where查询,我觉得跟这个关系不太大, 现在不知道怎么办,希望有思 ...

  8. os引导程序boot 在根目录区寻找os加载程序文件loader 对应的根目录条目

    [0]README 0.0) source code from orange's implemention of a os and for complete code , please visit h ...

  9. LeetCode -- Flatten 二叉树

    这个题目主要考察二叉树的先序遍历. 1. 先序遍历2. 节点用队列存储3. 遍历队列,建立链表 实现: public class Solution { public void Flatten(Tree ...

  10. NuGet管理工具安装

    安装完成后VS重启即可