codevs2215 三角形蛋糕
codevs2215 三角形蛋糕
煞笔题???
开始一看似乎没啥思路的样子
然后想了一下
额。。。
首先啃腚考虑缩进存储
然后看一下这样的性质
#-##----#
 -----#-
  ---#-
   -#-
    -
|
V
#-##----#
-----#-
---#-
-#-
-
and
-----
 ---
  -
|
V
-----
---
-
那么三角形就变成这个鬼样子了嘛。
那么设f[i][j]表示(i,j)为三角形最下面的那个点向上能扩展的最多行数
s[i][j]='#'->f[i][j]=0
s[i][j]='-'->f[i][j]=min(f[i-1][j],f[i-1][j-1],f[i-1][j-2])+1
答案为\(max\){\(f[i][j]^2\)}.
然后你会发现WA了
答案小了
原因是三角形可能有倒的
重新YY出另一个状态:
那么设f[i][j]表示(i,j)为三角形最上面的那个点向下能扩展的最多行数
转移差不多,可以看代码
然后你会发现再次WA
答案大了(QwQ)
原因是。。。
一个点可能无法更新答案但还是更新了!!!
比如这个点对应的三角形是倒的 然而更新了正的状态,特判一下
Code
// It is made by XZZ
#include<cstdio>
#include<algorithm>
#define Fname "trigon"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
    rg int x=0;rg char ch=getchar();
    while(ch<'0'||ch>'9')ch=getchar();
    while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
    return x;
}
char c[101][202];
int f[101][202],g[101][202];
int main(){
    #ifdef xzz
    freopen(Fname".in","r",stdin);
    freopen(Fname".out","w",stdout);
    #endif
    int n=gi();
    rep(i,1,n)scanf("%s",c[i]+1);
    int ans=0;
    rep(i,1,n*2-1)if(c[1][i]!='#')f[1][i]=ans=1;
    rep(i,2,n)drep(j,(n-i)*2+1,1){
	if(c[i][j]!='#')f[i][j]=min(f[i-1][j],min(f[i-1][j+1],f[i-1][j+2]))+1;
	if(j&1)ans=max(ans,f[i][j]);
    }
    if(c[n][1]=='#')g[n][1]=1;
    drep(i,n-1,1)drep(j,(n-i)*2+1,1){
	if(j<3||j>(n-i-1)*2+1)g[i][j]=c[i][j]=='-';
	else if(c[i][j]!='#')g[i][j]=min(g[i+1][j],min(g[i+1][j-1],g[i+1][j-2]))+1;
	if(!(j&1))ans=max(ans,g[i][j]);
    }
    printf("%d\n",ans*ans);
    return 0;
}
												
											codevs2215 三角形蛋糕的更多相关文章
- ZOJ 3537 Cake (区间DP,三角形剖分)
		
题意: 给出平面直角坐标系上的n个点的坐标,表示一个多边形蛋糕,先判断是否是凸多边形,若否,输出"I can't cut.".若是,则对这个蛋糕进行3角形剖分,切n-3次变成n-2 ...
 - canvas快速绘制圆形、三角形、矩形、多边形
		
想看前面整理的canvas常用API的同学可以点下面: canvas学习之API整理笔记(一) canvas学习之API整理笔记(二) 本系列文章涉及的所有代码都将上传至:项目代码github地址,喜 ...
 - Android快乐贪吃蛇游戏实战项目开发教程-05虚拟方向键(四)四个三角形按钮
		
该系列教程概述与目录:http://www.cnblogs.com/chengyujia/p/5787111.html 一.如何判断点击的是哪个方向键按钮 在上篇教程中我们实现了左边的三角形按钮效果, ...
 - Android快乐贪吃蛇游戏实战项目开发教程-04虚拟方向键(三)三角形按钮效果
		
该系列教程概述与目录:http://www.cnblogs.com/chengyujia/p/5787111.html 一.知识点讲解 当我们点击系统自带的按钮时,按钮的外观会发生变化.上篇博文中我们 ...
 - Android快乐贪吃蛇游戏实战项目开发教程-03虚拟方向键(二)绘制一个三角形
		
该系列教程概述与目录:http://www.cnblogs.com/chengyujia/p/5787111.html 一.绘制三角形 在上一篇文章中,我们已经新建了虚拟方向键的自定义控件Direct ...
 - 酷酷的CSS3三角形运用
		
概述 在早期的前端Web设计开发年代,完成一些页面元素时,我们必须要有专业的PS美工爸爸,由PS美工爸爸来切图,做一些圆角.阴影.锯齿或者一些小图标. 在CSS3出现后,借助一些具有魔力的CSS3属性 ...
 - CSS制作三角形和按钮
		
CSS制作三角形和按钮 用上一篇博文中关于边框样式的知识点,能制作出三角形和按钮. 我先说如何制作三角形吧,相信大家在平时逛网站的时候都会看到一些导航栏中的三角形吧,比如说: 网易首页的头部菜单栏中, ...
 - Effective前端3:用CSS画一个三角形
		
p { text-indent: 2em } .triangle-container p { text-indent: 0 } img { margin: 15px 0 } 三角形的场景很常见,打开一 ...
 - 通过CSS的border绘制三角形
		
通过css的border 可以绘制出三角形, 不同的样式组合,有着不同的效果,可以控制它的大小,颜色,方向.看下面各种图形,相信可能还有很多图形,大家都没见过. 先写出公共的样式: .border { ...
 
随机推荐
- 【redis运维】redis自己主动安装脚本(仅仅安装redis)
			
Redis自己主动安装部署 本文总共分为4个部分: redis自己主动安装脚本文件夹结构说明: redis自己主动安装脚本内容: redis的操作系统服 ...
 - Django中模型(一)
			
Django中模型(一) 一. 基本开发流程 1. 配置数据库 2. 定义模型类:一个模型类都在数据库中对应一张数据表 3. 生成迁移文件 4. ...
 - 查看oracle中表的索引
			
oracle中表的索引信息存在 user_indexes 和 user_ind_columns 两张表里面, 其中, user_indexes 系统视图存放是索引的名称以及该索引是否是唯一索引等信息, ...
 - linux 下 chkconfig安装与使用详解
			
chkconfig 安装 开始的时候因为Raspbian的原因,系统是不自带chkconfig这个命令的, root@raspberrypi:~# chkconfig-bash: chkconfig: ...
 - Loadrunner之HTTP接口测试
			
Loadrunner之HTTP接口测试 接口测试的原理是通过测试程序模拟客户端向服务器发送请求报文,服务器接收请求报文后对相应的报文做出处理然后再把应答报文发送给客户端,客户端接收应答报文这一个过程. ...
 - HDU 1004 Let the Balloon Rise(map的使用)
			
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1004 Let the Balloon Rise Time Limit: 2000/1000 MS (J ...
 - C#中调用方法
			
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threa ...
 - Myeclipse2014无法启动,启动十分之一自动闪退,闪退
			
现象: Myeclipse2014 无法启动 闪退 配图: 解决办法: 删掉 {workspace}/.metadata/.plugins/org.eclipse.e4.workbench/work ...
 - php无限极分类处理
			
/** * 无限极分类处理(通过递归方式实现) * @param $section 原始数据Array * @param $html 界面显示前缀,比如 |- * @param $spear 分级中所 ...
 - rpm与yum,at与crontab,sed命令使用
			
1.简述rpm与yum命令的常见选项,并举例. rpm——软件包管理系统,它使得在Linux下安装.升级.删除软件包的工作变得容易,并且具有查询.验证软件包的功能. 1)安装选项 命令格式: rpm ...