Time Limit: 1 second

Memory Limit: 128 MB

【问题描述】

给出一个n*n的矩阵,矩阵中,有些格子被染成黑色,有些格子被染成黑色,现要求矩阵中白色矩形的数量。

【输入格式】

输入文件rec.in第一行,仅包含一个整数n,表示矩形的大小。 接下来n行,每行n个字符,这些字符为“W”或“B”。其中“W”表示白格,“B”表示黑格。

【输出格式】

输出文件rec.out仅包括一个正整数,为白色矩形数量

【数据规模】

对于30%的数据,n ≤ 50; 对于100%的数据,n ≤ 150;

Sample Input1

4
WWBW
BBWB
WBWW
WBWB

Sample Output1

15

【题解】

这题有比较特殊的技巧。

设f[i][j]表示(i,j)这个白砖下面有连续几个白砖。

对于枚举到的白砖(i,j),令L=f[i][j];

答案累加L。

然后令k=j+1.不断往右枚举。

L=min(L,f[i][k])。如果f[i][k]==0则停止递增k.

否则答案累加L。

然后枚举所有的白砖即可。

原理如下。下面的1表示白砖。

假设当前i=1,j=1;

L=f[1][1]==3;

答案先累加L == 3;(表示3个长度为1的砖。如下图)

然后往右。答案再累加L==3(表示3个长度为2宽为1的砖);

跳过其他的点

然后i=2,j=1;

L=f[2][1];

答案先累加L==2;(第一列,竖下来,2个宽度为1,长为2的矩形);

如下图:

然后i=2,j=2;

L=min(L,f[2][1]);然后L仍然等于2;

所以答案再累加上2.(两列,竖下来,2个宽度为2,长为2的矩形如下图)

跳过其他点。

然后i=3,j=1;

L=f[3][1] == 1;

答案先累加L==1;

表示一个长为1,高为3的矩形,如下图;

然后往右i=3,j=2;

L仍然为1.答案累加L。

表示一个宽为2,高为3的矩形。

特殊的。

对于下面这种情况。

当i=2,j=1时,往右枚举时。加上L=2.表示的是下图的情况。

通过以上例子。

如果某个砖块下面还有砖。(白)

那么在对上面的砖操作之后。比如还会对下面的砖进行操作。

然后我们在对下面的砖进行操作的时候。实际上就是在枚举上面那个砖的右下角。

再往下的i-2号砖,也是一样在枚举最上面那个砖的右下角。

然后最上面那个砖作为左上角。

特殊的。认为只有一块砖的矩形是由最上面那个砖自己构成左上和右下组成的。

所以我们在枚举最上面那块砖下面的砖的时候。如果往右递增答案了。就相当于扩展了

矩形的右下角。

然后枚举的左上到右下这样的矩形个数恰

好为min(左上角下面的矩形数,右下角下面的白矩形)

这个左上角是会发生变化的。

就像上面那个图一样。

【代码】

#include <cstdio>
#include <iostream>
#include <string>
#include <cstring> using namespace std; int n;
string s;
bool bo[151][151];
int f[151][151] = { 0 }; void input_data()
{
memset(bo, false, sizeof(bo));
scanf("%d", &n);
for (int i = 1; i <= n; i++)
{
cin >> s;
for (int j = 1; j <= n; j++) //是白色的就记录一下。
if (s[j - 1] == 'W')
bo[i][j] = true; //转换成bool型数组。
}
} int min(int x, int y) //返回x和y之间的最小值。
{
return x > y ? y : x;
} void get_ans()
{
for (int i = 1;i <= n;i++)
for (int j = 1;j <= n;j++)
if (bo[i][j]) //如果是白的砖
{ //则求出其(包括其)下面有多少个砖
int k = i;
while (bo[k-1][j]) k--;
f[i][j] = i - k + 1;
}
int ans = 0; //这是最后要输出的答案
for (int i = 1;i <= n;i++)
for (int j = 1;j <= n;j++)
if (f[i][j] > 0) //如果这个转是白砖。
{
int l = f[i][j];
ans += l; //先累加上答案。
int k = j + 1; //往右移动。
while (f[i][k] > 0) //如果还是大于0.则可以扩展右下角。
{
l = min(f[i][k], l);
ans += l; //累加相应的矩形个数即可。
k++;
}
}
printf("%d\n", ans);
} int main()
{
//freopen("F:\\rush.txt", "r", stdin);
//freopen("F:\\rush_out.txt", "w", stdout);
input_data();
get_ans();
//fclose(stdin);
//fclose(stdout);
return 0;
}
												

【u126】矩形的更多相关文章

  1. [BOT] 一种android中实现“圆角矩形”的方法

    内容简介 文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式,四个角可以分别指定为圆角.思路是利用"Xfermode + Path"来进行 ...

  2. C语言 · 矩形面积交

    问题描述 平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴.对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积. 输入格式 输入仅包含两行,每行描述一个矩形. 在每行中 ...

  3. canvas快速绘制圆形、三角形、矩形、多边形

    想看前面整理的canvas常用API的同学可以点下面: canvas学习之API整理笔记(一) canvas学习之API整理笔记(二) 本系列文章涉及的所有代码都将上传至:项目代码github地址,喜 ...

  4. [LeetCode] Perfect Rectangle 完美矩形

    Given N axis-aligned rectangles where N > 0, determine if they all together form an exact cover o ...

  5. [LeetCode] Rectangle Area 矩形面积

    Find the total area covered by two rectilinear rectangles in a2D plane. Each rectangle is defined by ...

  6. [LeetCode] Maximal Rectangle 最大矩形

    Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and ...

  7. [LeetCode] Largest Rectangle in Histogram 直方图中最大的矩形

    Given n non-negative integers representing the histogram's bar height where the width of each bar is ...

  8. [翻译svg教程]svg中矩形元素 rect

    svg 元素<rect> 是一个矩形元素,用这个元素,可以你可以绘制矩形,设置矩形宽高,边框的宽度颜色,矩形的填充颜色,是否用圆角等 rect 示例 <svg xmlns=" ...

  9. C# GDI绘制矩形框,鼠标左键拖动可移动矩形框,滚轮放大缩小矩形框

    最近工作需要,要做一个矩形框,并且 用鼠标左键拖动矩形框移动其位置.网上查了一些感觉他们做的挺复杂的.我自己研究一天,做了一个比较简单的,发表出来供大家参考一下.如觉得简单,可路过,谢谢.哈哈. 先大 ...

随机推荐

  1. 【代码】Django学习笔记

    一些设置setting.py DEBUG = True ALLOWED_HOSTS = ['*'] DATABASES = { 'default': { 'ENGINE': 'django.db.ba ...

  2. 设计模式六大原则(三):依赖倒置原则(Dependence Inversion Principle)

    依赖倒置原则(DIP)定义: 高层模块不应该依赖低层模块,二者都应该依赖其抽象:抽象不应该依赖细节:细节应该依赖抽象. 问题由来: 类A直接依赖类B,假如要将类A改为依赖类C,则必须通过修改类A的代码 ...

  3. BZOJ 3732 Network Kruskal+倍增LCA

    题目大意:给定一个n个点m条边的无向连通图.k次询问两点之间全部路径中最长边的最小值 NOIP2013 货车运输.差点儿就是原题...仅仅只是最小边最大改成了最大边最小.. . 首先看到最大值最小第一 ...

  4. Android ProGuard代码混淆技术详解

    前言     受<APP研发录>启发,里面讲到一名Android程序员,在工作一段时间后,会感觉到迷茫,想进阶的话接下去是看Android系统源码呢,还是每天继续做应用,毕竟每天都是画UI ...

  5. python内存增长问题

    如果你的程序没有调用什么特殊的库, 只是用了很平常的库, 而且使再循环很多的情况下, 那么建议你把循环里的程序拆出来,写成一子函数,循环子函数. 如下面格式: for   (循环) 子函数 这样程序每 ...

  6. Vue 自定义全局消息框组件

    消息弹框组件,默认3秒后自动关闭,可设置info/success/warning/error类型 效果图: 文件目录: Message.vue <template> <transit ...

  7. Android实践之ScrollView中滑动冲突处理

    转载注明出处:http://blog.csdn.net/xiaohanluo/article/details/52130923 1. 前言 在Android开发中,假设是一些简单的布局.都非常easy ...

  8. log4j配置文件及nutch中的日志配置 分类: B1_JAVA 2015-02-17 10:58 483人阅读 评论(0) 收藏

    吐槽几句,log4j的坑啊.... (1)CLASSPATH中不能有多个log4j的版本本,否则有有奇形怪状的NoSuchMethod, NoSuchFiled, NoClassDefineFound ...

  9. Android Material风格的应用(一)--AppBar TabLayout

    打造Material风格的Android应用 Android Material风格的应用(一)--AppBar TabLayoutAndroid Material风格的应用(二)--RecyclerV ...

  10. 打开utf-8文件乱码的解决方法

    gvim一直用的好好的,但是今天看一网友贴出来的代码时,却发现中文显示乱码了.... 使用notepad++打开,右下角显示是utf-8 w/0 BOM. 马上放狗, 发现解决方法如下:   在_vi ...