【USACO】packrec
这道题卡了很久,开始没读清楚题,没看到题目中给的6个组合是仅可能的组合,一直自己想有多少种组合方式。后来才发现,于是就想到写遍历。我想的是,这六种情况下,每个位置摆哪个矩形是不确定的,于是可以对方块的排列方法遍历,对每个方块是横放还是竖放遍历。写了一个9层的循环,效率很低,有非常多的重复。不过通过了。
#include <stdio.h>
#include <stdlib.h>
#include <math.h> typedef struct
{
int x;
int y;
}RECTANGLE; typedef struct
{
RECTANGLE r[];
}RECRotate; int cmp(const void *a1, const void *a2)
{
return ((RECTANGLE *)a1)->x - ((RECTANGLE *)a2)->x;
} int max(int a, int b)
{
return a > b ? a : b;
}
int min(int a, int b)
{
return a < b ? a : b;
} int assem(int c, RECTANGLE r1, RECTANGLE r2, RECTANGLE r3, RECTANGLE r4, RECTANGLE *out)
{
switch(c)
{
case :
out->x = r1.x + r2.x + r3.x + r4.x;
out->y = max(r4.y, max(r3.y, max(r1.y, r2.y)));
break;
case :
out->x = max(r4.y, r1.x + r2.x + r3.x);
out->y = max(r3.y, max(r1.y, r2.y)) + r4.x;
break;
case :
out->x = max(r1.x + r2.x + r3.x, r3.x + r4.y);
out->y = max(r1.y + r4.x, max(r3.y, r2.y + r4.x));
break;
case : //basic 4 and basic 5 have the same area
out->x = max(r2.x, r3.x) + r1.x +r4.x;
out->y = max(r2.y + r3.y, max(r1.y, r4.y));
break;
case :
if(r3.y >= r4.y)
{
out->x = max(r2.y + r3.x, max(r3.x + r4.x, r1.x + r2.y));
out->y = max(r1.y + r3.y, r2.x + r4.y);
}
break;
default:
break;
}
return ;
} int isfirst(RECTANGLE *outr, int num, RECTANGLE tmp) //判断答案是否第一次出现 因为计算有冗余 可能有相同答案出现多次
{
int i;
for(i = ; i < num; i++)
{
if(tmp.x == outr[i].x || tmp.y == outr[i].x)
{
return ;
}
}
return ;
}
int main()
{
FILE *in, *out;
RECRotate recin[]; //原始输入矩阵
RECTANGLE outr[]; int i, j[], k[];
in = fopen("packrec.in", "r");
out = fopen("packrec.out", "w"); for(i = ; i < ; i++)
{
fscanf(in, "%d %d", &recin[i].r[].x, &recin[i].r[].y);
recin[i].r[].x = recin[i].r[].y;
recin[i].r[].y = recin[i].r[].x;
} RECTANGLE R1;
RECTANGLE R2;
RECTANGLE R3;
RECTANGLE R4;
RECTANGLE OUTTMP;
int minarea = ;
int outnum = ;
for(j[] = ; j[] < ; j[]++) //对每个位置采用第几个方块遍历
{
for(j[] = ; j[] < ; j[]++)
{
if(j[] == j[]) continue;
for(j[] = ; j[] < ; j[]++)
{
if(j[] == j[] || j[] == j[]) continue;
for(j[] = ; j[] < ; j[]++)
{
if(j[] == j[] || j[] == j[] || j[] == j[]) continue;
for(k[] = ; k[] < ; k[]++)
{
for(k[] = ; k[] < ; k[]++) //对每个方块采用横放竖放遍历
{
for(k[] = ; k[] < ; k[]++)
{
for(k[] = ; k[] < ; k[]++)
{
R1 = recin[j[]].r[k[]];
R2 = recin[j[]].r[k[]];
R3 = recin[j[]].r[k[]];
R4 = recin[j[]].r[k[]];
for(i = ; i < ; i++) //对6种情况遍历
{
assem(i, R1, R2, R3, R4, &OUTTMP);
if(OUTTMP.x * OUTTMP.y < minarea)
{
minarea = OUTTMP.x * OUTTMP.y;
outnum = ;
outr[outnum - ] = OUTTMP;
}
else if(OUTTMP.x * OUTTMP.y == minarea && isfirst(outr, outnum, OUTTMP))
{
outnum++;
outr[outnum - ] = OUTTMP;
}
}
}
}
}
}
}
}
}
}
for(i = ; i < outnum; i++) //令短边长在前
{
if(outr[i].x > outr[i].y)
{
int tmp = outr[i].x;
outr[i].x = outr[i].y;
outr[i].y = tmp;
}
}
qsort(outr, outnum, sizeof(outr[]), cmp); //按照短边长从小到大输出 fprintf(out, "%d\n", minarea);
for(i = ; i < outnum; i++)
{
fprintf(out, "%d %d\n", outr[i].x, outr[i].y);
} return ;
}
【USACO】packrec的更多相关文章
- POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 【USACO】距离咨询(最近公共祖先)
POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 [USACO]距离咨询(最近公共祖先) Description F ...
- 1642: 【USACO】Payback(还债)
1642: [USACO]Payback(还债) 时间限制: 1 Sec 内存限制: 64 MB 提交: 190 解决: 95 [提交] [状态] [讨论版] [命题人:外部导入] 题目描述 &quo ...
- 1519: 【USACO】超级书架
1519: [USACO]超级书架 时间限制: 1 Sec 内存限制: 64 MB 提交: 1735 解决: 891 [提交] [状态] [讨论版] [命题人:外部导入] 题目描述 Farmer Jo ...
- Java实现【USACO】1.1.2 贪婪的礼物送礼者 Greedy Gift Givers
[USACO]1.1.2 贪婪的礼物送礼者 Greedy Gift Givers 题目描述 对于一群要互送礼物的朋友,你要确定每个人送出的礼物比收到的多多少(and vice versa for th ...
- 【CPLUSOJ】【USACO】【差分约束】排队(layout)
[题目描述] Robin喜欢将他的奶牛们排成一队.假设他有N头奶牛,编号为1至N.这些奶牛按照编号大小排列,并且由于它们都很想早点吃饭,于是就很可能出现多头奶牛挤在同一位置的情况(也就是说,如果我们认 ...
- 【USACO】Dining
[题目链接] [JZXX]点击打开链接 [caioj]点击打开链接 [算法] 拆点+网络流 [代码] #include<bits/stdc++.h> using namespace std ...
- 【USACO】Optimal Milking
题目链接 : [POJ]点击打开链接 [caioj]点击打开链接 算法 : 1:跑一遍弗洛伊德,求出点与点之间的最短路径 2:二分答案,二分”最大值最小“ 3.1:建边,将 ...
- 【USACO】 Balanced Photo
[题目链接] 点击打开链接 [算法] 树状数组 [代码] #include<bits/stdc++.h> using namespace std; int i,N,ans,l1,l2; ] ...
- 【USACO】 Balanced Lineup
[题目链接] 点击打开链接 [算法] 这是一道经典的最值查询(RMQ)问题. 我们首先想到线段树.但有没有更快的方法呢?对于这类问题,我们可以用ST表(稀疏表)算法求解. 稀疏表算法.其实也是一种动态 ...
随机推荐
- Windows下python的配置
Windows下python的配置 希望这是最后一次写关于python的配置博客了,已经被python的安装烦的不行了.一开始我希望安装python.手动配置pip并使用pip安装numpy,然而发现 ...
- c链表实现遇到的错误
想完成一个链表发现有错误,代码如下: //http://ac.jobdu.com/problem.php?pid=1511 //֮ǰÓÃlistʵÏֵģ¬½ñÌìÊÔÒ»ÏÂÓÃstruct ...
- WebBrowser 禁用右键
禁用错误脚本提示 将 WebBrowser控件的 ScriptErrorsSuppressed 设为 true 禁用右键菜单 将 WebBrowser 的 IsWebBrowserContextMen ...
- HTTP协议详解(一直在用可是这篇太好了转一下)
引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1. ...
- ashx 获取ajax Post到后台json数据
前台页面代码: var json = [{ "Name": "Pavan Kumar Pabothu", "Age": 27, " ...
- Windows 下 tail 查看日志命令工具分享
以前在公司时服务器上面可以实现tail 命令查看程序运行日志,感觉相当不错,上网查了下这些命令是linux 下的,还好有好心人开发了一个可以在Windows下的运行的小工具,来给分享一下: 使用方法: ...
- matlab之round any size rat isscalar ismatrix mean find max
1.round : 四舍五入 例子:a = [-1.9, -0.2, 3.4, 5.6, 7.0, 2.4+3.6i] round(a): [-2 0 3 6 7 2 4] 2.butte ...
- Drainage Ditches(dinic)
Drainage Ditches Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 59210 Accepted: 2273 ...
- cocos2dx新研发的游戏,手机运行时非常热的解决方案
cocos2dx新研发的游戏,手机运行时非常热,有需要的朋友可以参考下. cocos2dx新研发的游戏,手机上运行时导致手机非常热,后来听其他项目组分享时得知,可以通过降帧解决这个问题,原来是coco ...
- MVC中html转义问题(直接输出html的方法)
MVC中如果用@string(string是包含html代码的字符串)形式输出字符串,那么对应的html标签会自动转义,如果想直接输出html可用以下方法: @(new HtmlString( &qu ...