本来是USACO Training的1.4.1的,但是介于今早过了食物链想起了这道题实在是太怨念了,翻出自己写的AC程序居然有5KB!!

思路很简单,枚举,而且就图中的六种情况。但是第六种变化状况太多了,我自己根本就没写出来后来是看别人写的分四种情况Blah Blah...

可参考此篇中的分析:http://blog.sina.com.cn/s/blog_5c717d190100qgkr.html

program packrec;
var r,rw,rt:array[..,..] of integer;
i,j,k,l,t,i1,j1,k1,l1:integer;
ans,anscount:integer;
ansx,ansy:array [..] of integer; procedure swap(var a,b:integer);
var t:integer;
begin
t:=a;a:=b;b:=t;
end; procedure panding(x,y:integer);
begin
if x*y<ans then
begin
ans:=x*y;
anscount:=;
ansx[anscount]:=x;
ansy[anscount]:=y;
exit;
end;
if x*y=ans then
begin
inc(anscount);
ansx[anscount]:=x;
ansy[anscount]:=y;
end;
end; procedure work;
var lx,ly,min,i,max:integer;
begin
{layout1}
lx:=rw[,]+rw[,]+rw[,]+rw[,];
ly:=;
for i:= to do
if rw[i,]>ly then ly:=rw[i,];
panding(lx,ly);
{layout2}
lx:=rw[,]+rw[,]+rw[,];
if rw[,]>lx then lx:=rw[,];
max:=;
for i:= to do
if rw[i,]>max then max:=rw[i,];
ly:=max+rw[,];
panding(lx,ly);
{layout3}
lx:=rw[,]+rw[,];
if rw[,]>lx then lx:=rw[,];
lx:=lx+rw[,];
ly:=rw[,]+rw[,];
if rw[,]>rw[,] then ly:=rw[,]+rw[,];
if rw[,]>ly then ly:=rw[,];
panding(lx,ly);
{layout4}
if rw[,]>rw[,] then lx:=rw[,] else lx:=rw[,];
lx:=lx+rw[,]+rw[,];
ly:=rw[,];
if rw[,]+rw[,]>ly then ly:=rw[,]+rw[,];
if rw[,]>ly then ly:=rw[,];
panding(lx,ly);
{layout5}
if rw[,]>rw[,] then lx:=rw[,] else lx:=rw[,];
lx:=lx+rw[,]+rw[,];
ly:=rw[,]+rw[,];
if rw[,]>ly then ly:=rw[,];
if rw[,]>ly then ly:=rw[,];
panding(lx,ly);
{layout6}
{if (rw[1,1]+rw[3,1]>rw[2,1]+rw[4,1]) then
lx:=rw[1,1]+rw[3,1]
else
lx:=rw[2,1]+rw[4,1];
if rw[1,2]+rw[2,2]>rw[3,2]+rw[4,2] then
ly:=rw[1,2]+rw[2,2]
else
ly:=rw[3,2]+rw[4,2];
if (rw[3,2]>rw[1,2]) and (rw[1,1]<rw[2,1]) then ly:=rw[2,2]+rw[4,2];
if (rw[1,1]>rw[2,1]) and (rw[3,2]>rw[2,2]) then ly:=rw[1,1]+rw[3,2];
if (rw[1,1]>rw[2,1]) and (rw[3,2]>rw[)}
if rw[,]+rw[,]>rw[,]+rw[,] then
ly:=rw[,]+rw[,]
else
ly:=rw[,]+rw[,];
if rw[,]>=rw[,]+rw[,] then
begin
lx:=rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
end;
if (rw[,]>rw[,]) and (rw[,]>rw[,]+r[,]) then
begin
lx:=rw[,]+rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
end;
if (rw[,]>rw[,]) and (rw[,]<rw[,]+rw[,]) then
begin
lx:=rw[,]+rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
end;
if (rw[,]>=rw[,]+rw[,]) then
begin
lx:=rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
end;
if rw[,]=rw[,] then
begin
lx:=rw[,]+rw[,];
if rw[,]+rw[,]>lx then lx:=rw[,]+rw[,];
end;
panding(lx,ly);
end; begin
assign(input,'packrec.in');reset(input);
assign(output,'packrec.out');rewrite(output);
ans:=;
for i:= to do
readln(r[i,],r[i,]);
for i:= to do
for j:= to do
if (j<>i) then
for k:= to do
if (k<>i) and (k<>j) then
for l:= to do
if (l<>i) and (l<>j) and (l<>k) then
begin
rw[,]:=r[i,];rw[,]:=r[i,];
rw[,]:=r[j,];rw[,]:=r[j,];
rw[,]:=r[k,];rw[,]:=r[k,];
rw[,]:=r[l,];rw[,]:=r[l,];
rt:=rw;
for i1:= to do
for j1:= to do
for k1:= to do
for l1:= to do
begin
rw:=rt;
if i1= then swap(rw[,],rw[,]);
if j1= then swap(rw[,],rw[,]);
if k1= then swap(rw[,],rw[,]);
if l1= then swap(rw[,],rw[,]);
work;
end;
end;
writeln(ans);
for i:= to anscount- do
for j:=i+ to anscount do
if ansx[i]<ansx[j] then
begin
swap(ansx[i],ansx[j]);
swap(ansy[i],ansy[j]);
end;
for i:= to anscount do
if (ansx[i]<>ansx[i-]) and (ansx[i]>=ansy[i]) then writeln(ansy[i],' ',ansx[i]);
close(input);close(output);
end.

packrec

通过日期是2013-11-08,也就是因为NOIP和学农撞日期旷课在家的那个周五0 0,简直是无法忘记那天有多么郁闷,备考的一天简直废在这题上面…⊙﹏⊙b

Section 1.4 Packing Rectangles的更多相关文章

  1. USACO 6.2 Packing Rectangles

    Packing RectanglesIOI 95 The six basic layouts of four rectangles Four rectangles are given. Find th ...

  2. USACO1.4.1 Packing Rectangles

    //毕竟我不是dd牛,USACO的题解也不可能一句话带过的…… 题目链接:http://cerberus.delos.com:790/usacoprob2?a=pWvHFwGsTb2&S=pa ...

  3. [vijos P1531] 食物链

    做出的第一道NOI题目?(噗,还是看题解才会的…按某篇解题说的,这题就比我年轻四岁…T T 做的第一道IOI题目是USACO上的Packing Rectangles...这题比我还老!)对我等弱渣来说 ...

  4. USACO chapter1

    几天时间就把USACO chapter1重新做了一遍,发现了自己以前许多的不足.蒽,现在的程序明显比以前干净很多,而且效率也提高了许多.继续努力吧,好好的提高自己.这一章主要还是基本功的训练,没多少的 ...

  5. pdf reference 格式具体说明

    1. PDF概要 1.1. 图像模型 PDF能以平台无关.高效率的方式描叙复杂的文字.图形.排版. PDF 用图像模型来实现设备无关. 图像模型同意应用程序以抽象对象描叙文字.图像.图标.而不是通过详 ...

  6. Determine overlapping rectangles

    https://github.com/Premiumlab/Python-for-Algorithms--Data-Structures--and-Interviews/blob/master/Moc ...

  7. keil MDK error: L6236E: No section matches selector - no section 错误

    今天板子刚到,新建的第一个工程就报错了. .\Objects\cse.sct(7): error: L6236E: No section matches selector - no section t ...

  8. 【代码笔记】iOS-一个tableView,两个section

    一,效果图. 二,工程图. 三,代码. RootViewController.h #import <UIKit/UIKit.h> @interface RootViewController ...

  9. gcc/linux内核中likely、unlikely和__attribute__(section(""))属性

    查看linux内核源码,你会发现有很多if (likely(""))...及if (unlikely(""))...语句,这些语句其实是编译器的一种优化方式,具 ...

随机推荐

  1. DOM加载:浏览器渲染和操作顺序(转载 学习中。。。)

    DOM加载:浏览器渲染和操作顺序 1.HTML解析完毕 2.外部脚本和样式表加载完毕 3.脚本在文档内解析并执行 4.HTML DOM完全构造起来 5.图片和外部内容加载 6.网页完成加载 基于这个顺 ...

  2. 转:c++内存分配

    第一篇: http://my.oschina.net/pollybl1255/blog/140323 BSS段:(bss segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域.BSS ...

  3. ORA-00205

    场景 数据库启动时报错.关闭前还是正常运行的,再次启动时,就报了以下错误. Copyright (c) , , Oracle. All rights reserved. Connected to an ...

  4. js boolean 判断

    在写项目的时候出现了一个这样的问题,虽然问题解决了,但是还是有点疑问. 在数据库中设计的表的一个字段为是否审核(is_vaild) 类型 tinyint(1) 对应的在 java中就是布尔类型(boo ...

  5. 微信公共平台php用$GLOBALS["HTTP_RAW_POST_DATA"]收不到信息解决方法

    http://www.cnblogs.com/shendiao/archive/2013/04/24/3041450.html <?php /** * wechat php test */ // ...

  6. imeOptions 属性详解

    默认情况下软键盘右下角的按钮为“下一个”,点击会到下一个输入框,保持软键盘 设置 android:imeOptions="actionDone" ,软键盘下方变成“完成”,点击后光 ...

  7. iOS 静态类库 打包 C,C++文件及和OC混编

    iOS 静态类库 编译 C,C++ 我们都知道,OC 原生支持C, 在 创建的 OC类的 .m 里面,可以直接编写C的代码: 同样 Xcode 也支持 OC ,C++的混编,此时,我们通常把OC创建的 ...

  8. 静态类和静态类成员(C# 编程指南)

    静态类与非静态类基本相同,但存在一个区别:静态类不能实例化. 也就是说,不能使用 new 关键字创建静态类类型的变量. 因为没有实例变量,所以要使用类名本身访问静态类的成员. 例如,如果名为 Util ...

  9. webstorm激活码

    2016.2.3版本 43B4A73YYJ-eyJsaWNlbnNlSWQiOiI0M0I0QTczWVlKIiwibGljZW5zZWVOYW1lIjoibGFuIHl1IiwiYXNzaWduZW ...

  10. spring来了-03-bean创建细节

    对象创建:单例/多例  [bean节点的属性scope] scope="singleton", 默认值,即默认是单例     [service/dao/工具类] scope=&qu ...