本来是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. [html] src与href的区别

    src用于替换当前元素,href用于在当前文档和引用资源之间确立联系. src是source的缩写,指向外部资源的位置,指向的内容将会嵌入到文档中当前标签所在位置:在请求src资源时会将其指向的资源下 ...

  2. Java Base64编码解码实现

    我尝试过两种方式:java自带的sun.misc的工具类,还有commons-codec.jar 1.sun.misc的工具类 String encoderStr = null; BASE64Enco ...

  3. 慢慢聊Linux AIO

    一.What:异步IO是什么? 1. 一句话总结 允许进程发起很多I/O操作,而不用阻塞或等待任何操作完成 2. 详细说说  一般来说,服务器端的I/O主要有两种情况:一是来自网络的I/O:二是对文件 ...

  4. word2010表格中的内容怎么设置行距

    选中表格,然后根据箭头指示点击 弹出如下对话框,选择行距

  5. go语言实战向导

    版权声明:本文由魏佳原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/173 来源:腾云阁 https://www.qclou ...

  6. call的其他应用

    看一些源码的时候常常发现例如这些的代码 Array.prototype.slice.call(arg) Object.prototype.toString.call(str) 等等 ,着一些系列的句子 ...

  7. 20145218《Java程序设计》第一周学习总结

    20145218 <Java程序设计>第一周学习总结 教材学习内容总结 今天下午看了Java学习的视频,感觉很是新奇,之前觉得Java学起来是艰难枯燥的,但通过第一章的学习觉得如果自己可以 ...

  8. ubuntu12.04 安装配置jdk1.7

    第一步:下载jdk-7-linux-i586.tar.gz wget -c http://download.oracle.com/otn-pub/java/jdk/7/jdk-7-linux-i586 ...

  9. nodeschool.io 6

    ~~ MAKE IT MODULAR ~~ This problem is the same as the previous but introduces the concept ofmodules. ...

  10. HTML5自学笔记[ 15 ]canvas绘图实例之钟表

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...