zoukankan      html  css  js  c++  java
  • hdu4517 游戏的烦恼

    小小明系列故事——游戏的烦恼

    Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)
    Total Submission(s): 609    Accepted Submission(s): 220


    Problem Description
      小小明最近在玩一款游戏,它由n*m大小的矩阵构成,矩阵上会随机产生一些黑色的点,这些点它们可能会连在一起也可能会分开,这些点的个数没有限制,但是每个1*1方格中最多只可能有一个黑点产生。游戏要求玩家以最短的时间用x*y的小矩阵覆盖这个大矩阵,覆盖的要求有以下2点:
      1. x*y大小的小矩阵内必须有x*y个黑点。
      2. 多个小矩阵可以重叠,但是每个小矩阵放置的位置必须是独一无二的,即不同的小矩阵内的黑点不能完全相同。例如1*2的矩阵可以横着放,也可以竖着放,这两种方法是不同的,即使它们可能共用黑点。
      小小明是个粗心的孩子,他尝试了很多遍都无法将所有的符合要求的小矩阵找到,聪明的你,能不能告诉烦恼中的小小明这个大矩阵里有多少个满足要求的小矩阵呢?
     
    Input
    题目有多组测试数据(不多于100个);
    每组测试数据的第一行包含2个正整数n和m,然后第二行是x和y(n,m,x,y的意思如题),接下来n行,每行m个字符,其中’ * ’表示黑点,’ . ’表示空白。
    n和m为0则结束输入。

    [Technical Specification]
    0 < n, m <= 2000
    0 < x, y <= 1000
     
    Output
    请计算并输出一共有多少个满足要求的小矩阵,每组输出占一行。
     
    Sample Input
    2 3 1 2 **. .** 0 0
     
    Sample Output
    3
     代码:
    #include<stdio.h>
    #include<string.h>
    int h[2010];
    char map[2010][2010];
    int calc(int n,int x,int y)
    {
        int i,cnt=0,j;
        int ret=0;
        for(i=0;i<n;++i)
        {
            if(h[i]>=x)
            {
                cnt=0;
                j=i;
                while(j<n&&h[j]>=x)
                {
                    cnt++;
                    j++;
                }
                i=j-1;
                if(cnt>=y)
                    ret+=cnt-y+1;
            }
        }
        return ret;
    }
    
    
    int main()
    {
        int x,y,n,m,ans,i,j;
        while(scanf("%d%d",&n,&m)&&(n!=0||m!=0))
        {
            scanf("%d%d",&x,&y);
            for(i=0;i<n;++i)
                scanf("%s",map[i]);
            memset(h,0,sizeof(h));
            ans=0;
            for(i=0;i<n;++i)
            {
                for(j=0;j<m;++j)
                {
                    if(map[i][j]=='*')
                        h[j]++;
                    else
                        h[j]=0;
                }
                ans+=calc(m,x,y);
                if(x!=y)
                    ans+=calc(m,y,x);
            }
            printf("%d\n",ans);
        }
        return 0;
    }

    全面COPY,

  • 相关阅读:
    2016年工作中遇到的问题11-20
    分布式服务框架Dubbo入门案例和项目源码
    分布式服务框架Dubbo入门案例和项目源码
    小米网抢购系统开发实践和我的个人观察
    小米网抢购系统开发实践和我的个人观察
    大学毕业4年-回顾和总结(8)-全局观-互联网项目研发-不在其位亦谋其政
    大学毕业4年-回顾和总结(8)-全局观-互联网项目研发-不在其位亦谋其政
    某电商项目的若干技术问题
    某电商项目的若干技术问题
    ZOJ 3861 Valid Pattern Lock
  • 原文地址:https://www.cnblogs.com/zibuyu/p/3127529.html
Copyright © 2011-2022 走看看