USACO Section 5.3 Big Barn(dp)
2015-03-16 21:38
330 查看
USACO前面好像有类似的题目..dp(i,j)=min(dp(i+1,j),dp(i+1,j+1),dp(i,j+1))+1 (坐标(i,j)处无tree;有tree自然dp(i,j)=0) 。dp(i,j)表示以坐标(i,j)为左上角的barn边长最大值,dp(i+1,j),dp(i,j+1)分别表示向右和向下能扩展的最大边长,但是以此为正方形时,右下方的一个格子没有考虑到,所以就+个dp(i+1,j+1)。边界为:dp(i,j)=1(i==n-1或j==n-1)。
-------------------------------------------------------------------------------
#include<cstdio>#include<iostream>#include<algorithm>#include<cstring>#define rep(i,r) for(int i=0;i<r;i++)#define clr(x,c) memset(x,c,sizeof(x))#define Rep(i,l,r) for(int i=l;i<r;i++)using namespace std;const int maxn=1000+5;int d[maxn][maxn];int ok[maxn][maxn];int n;int dp(int i,int j) { int &ans=d[i][j]; if(ans>=0) return ans; ans=0; if(!ok[i][j]) return ans; if(i==n-1 || j==n-1) return ans=1; return ans=min(dp(i+1,j+1),min(dp(i+1,j),dp(i,j+1)))+1; }int main(){ freopen("bigbrn.in","r",stdin); freopen("bigbrn.out","w",stdout); clr(ok,-1); int t; cin>>n>>t; rep(i,t) { int a,b; scanf("%d%d",&a,&b); ok[--a][--b]=0; } clr(d,-1); int ans=0; rep(i,n) rep(j,n) ans=max(ans,dp(i,j)); cout<<ans<<endl; return 0;}
-------------------------------------------------------------------------------
Big Barn
A Special TreatFarmer John wants to place a big square barn on his square farm. He hates to cut down trees on his farm and wants to find a location for his barn that enables him to build it only on land that is already clear of trees. For our purposes, his land is divided into N x N parcels. The input contains a list of parcels that contain trees. Your job is to determine and report the largest possible square barn that can be placed on his land without having to clear away trees. The barn sides must be parallel to the horizontal or vertical axis.
EXAMPLE
Consider the following grid of Farmer John's land where `.' represents a parcel with no trees and `#' represents a parcel with trees:1 2 3 4 5 6 7 8 1 . . . . . . . . 2 . # . . . # . . 3 . . . . . . . . 4 . . . . . . . . 5 . . . . . . . . 6 . . # . . . . . 7 . . . . . . . . 8 . . . . . . . .The largest barn is 5 x 5 and can be placed in either of two locations in the lower right part of the grid.
PROGRAM NAME: bigbrn
INPUT FORMAT
Line 1: | Two integers: N (1 <= N <= 1000), the number of parcels on a side, and T (1 <= T <= 10,000) the number of parcels with trees |
Lines 2..T+1: | Two integers (1 <= each integer <= N), the row and column of a tree parcel |
SAMPLE INPUT (file bigbrn.in)
8 3 2 2 2 6 6 3
OUTPUT FORMAT
The output file should consist of exactly one line, the maximum side length of John's barn.SAMPLE OUTPUT (file bigbrn.out)
5
相关文章推荐
- [luoguP2701] [USACO5.3]巨大的牛棚Big Barn(DP)
- Big Barn_usaco5.3_dp
- USACO 5.3 Big Barn(DP)
- [USACO5.3]巨大的牛棚Big Barn && 洛谷【p1387】最大正方形(动态规划)
- USACO Section 5.3 Big Barn - DP...
- USACO Section 5.3 Milk Measuring (IDDFS+dp)
- luoguP2701 [USACO5.3]巨大的牛棚Big Barn(极大子矩阵)
- USACO Section 5.3 Milk Measuring - DFSID+DP...
- USACO-Section 3.1 Humble Numbers(DP)
- hdu 4846 Big Barn【dp】
- USACO-Section 3.3 Shopping Offers (DP)
- USACO Section 5.3 Network of Schools - 回顾Tarjan求强连通分量
- USACO-Section 3.4 Raucous Rockers (DP)
- usaco 5.3 Big Barn(简单DP)
- USACO-Section 3.2 Stringsobits(DP)
- USACO-Section 3.3 A Game (区间DP)
- [IOI1996] USACO Section 5.3 Network of Schools(强连通分量)
- [DP]USACO Section 3.4 Raucous Rockers
- USACO: Section 1.3 -- PROB Barn Repair
- USACO-Section 4.3 Buy Low, Buy Lower (DP[LIS])