ZOJ2067 White Rectangles
来源:互联网 发布:mac装virtualbox 编辑:程序博客网 时间:2024/05/16 15:09
贪心, 数矩形的个数.
可以先把(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 110using 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;}
- ZOJ2067 White Rectangles
- ZOJ2067 White Rectangles 很好的DP递推啊
- White Rectangles
- hdu 1510 white rectangles
- White Rectangles(hdu 1510)
- zoj 2067 - White Rectangles
- 1510 White Rectangles
- ZOJ 2067 HDU 1510 White Rectangles
- hdu1510 White Rectangles(组合计数问题)
- Rectangles
- Rectangles
- Rectangles
- Rectangles
- Rectangles
- ZOJ2067 经典 DP
- White
- 1468 Rectangles
- Rectangles dp
- 第12周报告1
- oracle SQL*Plus出力csv
- 按钮状态--代码设定
- wget下载网站及使用html help workshop制作chm
- 第12周报告3
- ZOJ2067 White Rectangles
- 第13周报告1
- 黑苹果安装
- 字符流与字节流的区别
- QT qmessagebox设计资料
- 硬件调试点滴(一)
- 收缩菜单
- 第13周报告2
- 节点流和处理流