ZOJ2067 White Rectangles

本文介绍了一种通过动态规划解决计数白色矩形问题的算法。该算法首先记录每个位置作为矩形右下角时所能形成的矩形数量,再通过三层循环遍历所有可能的矩形组合,最终统计出总矩形数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

贪心, 数矩形的个数.

可以先把(x,y)为终点往左的矩形数记录下来, 这里可以应用DP的方法

然后O(n^3)循环, 说不清楚, 看代码吧.


/*******************************************************************************
 # Author : Neo Fung
 # Email : neosfung@gmail.com
 # Last modified: 2012-02-29 20:24
 # Filename: ZOJ2067 White Rectangles.cpp
 # Description : 
 ******************************************************************************/
#ifdef _MSC_VER
#define DEBUG
#define _CRT_SECURE_NO_DEPRECATE
#endif

#include <fstream>
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <string>
#include <limits.h>
#include <algorithm>
#include <math.h>
#include <numeric>
#include <functional>
#include <ctype.h>
#define MAX 110
using namespace std;

char board[MAX][MAX];
int sum[MAX][MAX];

int main(void)
{
#ifdef DEBUG  
  freopen("../stdin.txt","r",stdin);
  freopen("../stdout.txt","w",stdout); 
#endif  

  int n;
  while(~scanf("%d",&n))
  {
    memset(sum,0,sizeof(sum));
    memset(board,'#',sizeof(board));
    getchar();
    for(int i=1;i<=n;++i)
      gets(board[i]+1);

		int ans=0;

		for(int i=1;i<=n;++i)
			for(int j=1;j<=n;++j)
				if(board[i][j]=='.')
				{
					if(board[i][j-1]!='.')
						sum[i][j]=1;
					else
            sum[i][j]=sum[i][j-1]+1;
				}

		for(int i=1;i<=n;++i)
			for(int j=1;j<=n;++j)
			{
				int len=INT_MAX;
				for(int k=i;k<=n && sum[k][j];++k)
				{
					len=min(len,sum[k][j]);
					ans+=len;
				}
			}
		printf("%d\n",ans);
  }

  return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值