uva12265 抓关键 矩形利用对角两点

来源:互联网 发布:淘宝菜鸟驿站加盟 编辑:程序博客网 时间:2024/05/19 01:13
  1. 题目要抓住关键,这道题的关键是通过矩形的左上角定位矩形。
  2. 保存可能的最优解,并进行更新的思想。
  3. 一步一步想,要追求逻辑层次,画出来,不要贪快。例如:行往下遍历,列往右遍历,通过递增计算出来高度,通过一个数组保存可能的解并更新。
  4. 利用数组下标模拟栈。

题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=23887

#include <cstdio>#include <cstring>using namespace std;const int maxn = 1000 + 10;char s[maxn][maxn];int height[maxn], ans[maxn << 1];struct Rect//表示左上角的当前列和高度{    int c, h;    //构造函数,前面的是形参,冒号后面的语句是给数据初始化为形参。默认一个值是一个好的习惯,但实际意义不大。    Rect(int cc = 1, int hh = 1):c(cc), h(hh) {}}rect[maxn];int n, m;int main(){    int T; scanf("%d", &T);    while(T--)    {        scanf("%d%d", &n, &m);        for(int i = 0; i < n; i++) scanf("%s", s[i]);        memset(height, 0, sizeof(height));        memset(ans, 0, sizeof(ans));        for(int i = 0; i < n; i++)//先行后列遍历        {            int top = -1;//舒适化一个标识            for(int j = 0; j < m; j++)            {                if(s[i][j] == '#')                {                    top = -1;//通过操作下标来模拟栈,效率高。                    height[j] = 0;                }                else                {                    height[j]++;//当前列的高度递推得到                    Rect r(j, height[j]);                    if(top < 0) rect[++top] = r;    //空栈直接赋值                    else                    {                        while(top >= 0 && rect[top].h >= r.h) r.c = rect[top--].c; //栈中的h应等于最左边碰到墙位置的c,扁平型                        if(top < 0 || r.h - r.c > rect[top].h - rect[top].c) rect[++top] = r;//如果有最优解,那么加入栈                    }                    r = rect[top];                    ans[r.h + j - r.c + 1]++;                }            }        }        for(int i = 2; i <= m + n; i++)//将结果直接保存在数组中,对应的下标进行计数。            if(ans[i]) printf("%d x %d\n", ans[i], i * 2);    }    return 0;}
1 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 十一个月宝宝断奶不喝奶粉怎么办 孩子三门成绩全不及格家长该怎么办 宝宝快十个月了还不会爬怎么办 小孩写字老把手向里扭曲怎么办 孩子该上四年级了数学差的很怎么办 孩子上三年级了数学成绩好差怎么办 三年级数学老考70-80分怎么办 叛逆期的孩子用死来威胁家长怎么办 叛逆期的孩子抽烟喝酒家长该怎么办 大学遇到不好的老师加课怎么办 两岁的宝宝脾气古怪不听话怎么办 16个月宝宝不听话脾气大怎么办 如果你很害怕去面对一件事怎么办 孩子上幼儿园哭老师不理孩子怎么办 发现幼儿园给孩子吃药片该怎么办 做老师的打学生被家长投诉怎么办 学生认为老师向家长打报告怎么办 老师发打12分的试卷给家长怎么办 孩子在学校顶撞老师不让上学怎么办 被老师骂了不敢去学校怎么办 孩子不爱去幼儿园 总是哭怎么办呢 孩子在幼儿园被老师罚家长该怎么办 孩子不喜欢幼儿园里的体能课怎么办 初中叛逆期的孩子怎么办老师做法 二年级孩子不受老师待见怎么办 孩子该上初中了没学籍怎么办 四个多月的婴儿不喜欢看人怎么办 2个月婴儿不喜欢吃奶粉怎么办 想学习但是又学不进去怎么办 在省外读书 回来读高中学籍怎么办 一岁宝宝这几天不爱吃饭怎么办 2岁的宝宝吃多了怎么办 小孩吃了退烧药吐了怎么办 牙齿与牙齿之间有洞喜欢塞牙怎么办 胃有点烧心天天没食欲不饿怎么办 1岁半宝宝不吃饭光喝奶粉怎么办 一岁半宝宝光喝奶粉不吃饭怎么办 一岁半的宝宝光喝奶粉不吃饭怎么办 两岁半宝宝光喝奶粉不吃饭怎么办 宝宝9个月不好好吃饭奶粉怎么办 2岁半宝宝不愿意自己吃饭怎么办