裁缝有一块非常珍贵的丝绸围巾。可惜的是,围巾的某些部分已经被蛀虫给咬坏了。裁缝当然不愿意就这么把围巾给丢了,于是,他想把围巾给裁成两块小围巾送给他的两个女儿。自然,两块小围巾的面积之和越大越好。 
这块围巾是一个正三角形,三条边被均匀地分成了N段,即这个正三角形被均匀地分成了N2个单元,每个单元是一个面积为1的正三角形。图一所 示为一个N=5的围巾,图中带阴影的单元表示被蛀虫咬坏的部分。从上往下看,围巾被分成了N行,第一行有1个单元,第二行有3个单元,其中有2个是形如D 的,有1个是形如Ñ 的(这两种三角形我们认为是形状相同的)。第三行有5个,其中有3个是形如D 的,有2个是形如Ñ 的…… 。用坐标(X,Y)给每个单元定位,第一行的单元的坐标为(1,1);第二行从左到右的三个单元的坐标依次为(2,1)、(2,2)、(2,3);

围巾的剪裁条件如下: 
裁成的两块小围巾形状与原来的大围巾完全相同,都是正三角形。 
每一块小围巾里都不存在被蛀虫咬坏的部分。 
裁剪时必须沿着单元的边界裁剪。 
要求两块小围巾的面积的总和最大。 
图中,最优的裁剪方法已经用粗线画了出来,面积和为4+9=13。 
现在需要你编一个程序来帮助裁缝解决这个问题。

Input

第一行为一个整数N(1<=N<=100),表示这块围巾总共被分成了N2个单元。第二行为一个整数M(0<= M<=N2-2),表示这块围巾共有M个单元被蛀虫咬坏了。 
接下的M行,每一行有两个正整数X和Y,为这M个被蛀虫咬坏的单元的坐标。 
输入文件中同一行相邻两项之间用一个或多个空格隔开。

Output

仅含一个整数,为你所找到的裁出两块小围巾面积总和的最大值。z

SS:用DP的方法;DP出每个小正三角形能延伸多少层,枚举割线,分成小三角形和梯形,取ans的最大值再旋转120度,循环3次继续DP下去

DP方程很好想到,a[i][2*j-1]=min(a[i+1][2*j-1],a[i+1][2*j+1])+1,
   a[i][2*j]=min(a[i-1][2*j],a[i-1][2*(j-1)])+1;

#include<iostream>
#include<cstdlib>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
int n,x,y,m,ans;
int a[10001][20001];
int b[10001][20001];
void make(){
for(int i=1;i<=n;++i)if(a[n][i*2-1]!=-1)a[n][i*2-1]=1;
for(int i=n-1;i>=1;--i)
for(int j=1;j<=i;++j)if(a[i][2*j-1]!=-1){
a[i][2*j-1]=1;
if(a[i+1][2*j-1]!=-1&&a[i+1][2*j]!=-1&&a[i+1][2*j+1]!=-1)
a[i][2*j-1]=min(a[i+1][2*j-1],a[i+1][2*j+1])+1;
}
for(int i=2;i<=n;++i)
for(int j=1;j<=i-1;++j)if(a[i][2*j]!=-1){
a[i][2*j]=1;
if(j!=1&&j!=i-1&&a[i-1][2*(j-1)+1]!=-1&&a[i-1][2*(j-1)]!=-1&&a[i-1][2*j]!=-1)
a[i][2*j]=min(a[i-1][2*(j-1)],a[i-1][2*j])+1;
}
}
void ask(){
int max1,max2;
for(int i=1;i<n;++i){//枚举分割线
max1=0,max2=0;
for(int j=1;j<=i;++j){
for(int k=1;k<=j;++k)max1=max(min(i-j+1,a[j][k*2-1]),max1);
for(int k=1;k<=j-1;++k)max1=max(a[j][k*2],max1);
}
for(int j=i+1;j<=n;++j){
for(int k=1;k<=j;++k)max2=max(a[j][k*2-1],max2);
for(int k=1;k<=j-1;++k)max2=max(max2,min(j-i,a[j][k*2]));
}
if(max1!=0&&max2!=0)ans=max(ans,max1*max1+max2*max2);
}
}
void splay(){
for(int i=1;i<=n;++i){
for(int j=1;j<=i;++j)
if(a[i][2*j-1]==-1)b[n-i+j][(n-i)*2+1]=-1;
for(int j=1;j<=i-1;++j)if(a[i][2*j]==-1)b[n-i+j+1][(n-i)*2+2]=-1;
}
for(int i=1;i<=n;++i)
for(int j=1;j<=2*i-1;++j)a[i][j]=b[i][j];
}
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=m;++i)scanf("%d%d",&x,&y),a[x][y]=-1;
for(int tt=1;tt<=3;++tt){
make();ask();
memset(b,0,sizeof(b));
splay();
}
printf("%d",ans);
return 0;
}

NOI全国赛(1998)——围巾裁剪的更多相关文章

  1. NOI全国赛(2001)--食物链

    今天写了道并查集的题,看来并查集的题刷少了,,,,,用法好神奇啊!!!开三倍并查集 用i表示自己,i+n存天敌,i+2*n存可以克制de,再逻辑判断一下即可. 所以,要意识到并查集的分类处理可以开不同 ...

  2. Codevs 1800 假面舞会 2008年NOI全国竞赛

    1800 假面舞会 2008年NOI全国竞赛 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 一年一度的假面舞会又开始了,栋栋也 ...

  3. Codevs 1074 食物链 2001年NOI全国竞赛

    1074 食物链 2001年NOI全国竞赛 时间限制: 3 s 空间限制: 64000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description 动物王国中有三类动物 A,B ...

  4. 1729 单词查找树 2000年NOI全国竞赛

    1729 单词查找树 2000年NOI全国竞赛 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 大师 Master         题目描述 Description 在进行文法分析的 ...

  5. 1074 食物链 2001年NOI全国竞赛

    1074 食物链 2001年NOI全国竞赛 时间限制: 3 s 空间限制: 64000 KB 题目等级 : 钻石 Diamond         题目描述 Description 动物王国中有三类动物 ...

  6. NOI模拟赛 Day1

    [考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...

  7. CODEVS 1074 食物链 2001年NOI全国竞赛(洛谷 P2024)

    题目描述 Description 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A吃B,B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并 ...

  8. 食物链 2001年NOI全国竞赛

    时间限制: 3 s 空间限制: 64000 KB 题目等级 : 钻石 Diamond   题目描述 Description 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A吃B ...

  9. 6.28 NOI模拟赛 好题 状压dp 随机化

    算是一道比较新颖的题目 尽管好像是两年前的省选模拟赛题目.. 对于20%的分数 可以进行爆搜,对于另外20%的数据 因为k很小所以考虑上状压dp. 观察最后答案是一个连通块 从而可以发现这个连通块必然 ...

随机推荐

  1. MyBatis中多对多关系的映射和查询

    先说一下需求: 在页面上显示数据库中的所有图书,显示图书的同时,显示出该图书所属的类别(这里一本书可能同时属于多个类别) 创建表: 笔者这里使用 中间表 连接 图书表 和 图书类别表,图书表中 没有使 ...

  2. 深圳尚学堂:Java中Class对象

    Java中生成Class对象和生成instance都有多种方式.所以只有弄清其中的原理,才可以深入理解.首先要生成Class对象,然后再生成Instance.那Class对象的生成方式有哪些呢,以及其 ...

  3. 光荣与梦想 | XMove动作捕捉系统(一)

    XMove是我和几个死党从2010年开始开发的一套人体动作捕捉系统,软硬件全部自行开发,投入了大量的精力,历经三年,发展四个版本. 今年春节回到老家,翻出了2011年春节时焊电路用过的松香和和硬盘角落 ...

  4. 程序员的一生时间90%是用在编程上,而剩余的10%是活在世界上。刚进CSDN的博客看到这么句话

    程序员的一生时间90%是用在编程上,而剩余的10%是活在世界上. 而自己呢?是个程序员呢还是个业余玩家!

  5. 打开phpmyadmin显示高级功能尚未完全设置部分功能未激活

    问题:老师,打开phpmyadmin显示高级功能尚未完全设置部分功能未激活,应该如何解决? 这是前一阵子学生问过我的一个问题,今天我就在博客里解答你的疑问吧. 总共三步可以搞定 1.导入相关文件到数据 ...

  6. Log4net 日志记录配置信息

    <log4net> <!--配置日志的级别,低于此级别的就不写到日志里面去 OFF.FATAL.ERROR, WARN, INFO, DEBUG, ALL --> <ro ...

  7. HNOI2015 Day 1

    HNOI2015的题还是非常漂亮的,几道题都有很大的借鉴意义,都有很强的思考性 T1亚瑟王(概率论) 描述:http://www.lydsy.com/JudgeOnline/problem.php?i ...

  8. groovy regex groups(groovy正则表达式组)

    先看一个java正则表达式的例子. import java.util.regex.Matcher; import java.util.regex.Pattern; public class TestM ...

  9. 读书笔记 effective c++ Item 30 理解内联的里里外外 (大师入场啦)

    最近北京房价蹭蹭猛涨,买了房子的人心花怒放,没买的人心惊肉跳,咬牙切齿,楼主作为北漂无房一族,着实又亚历山大了一把,这些天晚上睡觉总是很难入睡,即使入睡,也是浮梦连篇,即使亚历山大,对C++的热情和追 ...

  10. input解决浏览器记住密码问题

    <input type="password" name="" id="">可以这样写 <input type=" ...