BZOJ1105 [POI2007]石头花园SKA 贪心

[POI2007]石头花园SKA

Time Limit: 20 Sec  Memory Limit: 162 MB
Submit: 776  Solved: 237
[Submit][Status][Discuss]

Description

  Blue Mary是一个有名的石头收藏家。迄今为止,他把他的藏品全部放在他的宫殿的地窖中。现在,他想将他
的藏品陈列在他的花园中。皇家花园是一个边长为1000000000单位的平行于坐标轴的正方形。对于每个石头,Blue
 Mary都有一个他想放置的坐标,然后将他告诉他的属下。不幸的是,他忘了告诉他们坐标的顺序(比如无法分辨(
x,y)和(y,x))。属下们,就自己决定了每个石头的具体位置。为了保护他的藏品,Blue Mary决定建造一个篱笆来
保护他们。为了美学的需要,篱笆也被设计为平行于坐标轴的矩形。如果花园的布局知道了,那么就可以知道最短
长度的篱笆的布局。他的属下们需要变换石头的坐标使得篱笆的长度最少。每个石头只能从(x,y)变换为(y,x),由
于每个石头的重量不一样。属下们希望他们移动的石头的重量和最少。

Input

第一行包含一个数n,表示石头的数量
接下来n行分别描述n个石头的初始坐标和重量xi,yi,mi。
(0<=xi,yi<=1000000000,1<=mi<=2000
(2<=n<=1000000)

Output

一行包含两个数由一个空格分割。
最小的篱笆长度和最小的移动的石子的重量和

Sample Input

5
2 3 400
1 4 100
2 2 655
3 4 100
5 3 277

Sample Output

10 200

HINT

BZOJ1105  [POI2007]石头花园SKA 贪心

2018.4.17修改题面,不需要输出方案了.未重测!

题解:

  篱笆的长度最小是第一目标,应当优先考虑。易知,当所有石头的坐标都满足x<=y的时候,即全部在y=x直线的一侧之时,一定能够得到最小的周长,这时的周长就是第一个答案。

  而满足这一周长的方式不止一种,可以将这个矩形关于y=x直线做对称,总共有四种可能的情况,全部枚举一遍即可。

 #include<cstring>
#include<cmath>
#include<cstdio>
#include<algorithm>
#include<iostream> #define ll long long
#define inf 1000000007
#define N 1000007 #define Wb putchar(' ')
#define We putchar('\n')
#define rg register int
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-;ch=getchar();}
while(isdigit(ch)){x=(x<<)+(x<<)+ch-'';ch=getchar();}
return x*f;
}
inline void write(ll x)
{
if(x<) putchar('-'),x=-x;
if (x==) putchar();
int num=;char c[];
while(x) c[++num]=(x%)+,x/=;
while(num) putchar(c[num--]);
} int n,m,ans=inf;
int lx=inf,ly=inf,rx=-inf,ry=-inf;
struct Node
{
int x,y,w;
}a[N]; inline void solve(int lx,int ly,int rx,int ry)
{
#define judge(x,y) (x>=lx&&x<=rx&&y>=ly&&y<=ry)
int res=;
for (int i=;i<=n;i++)
{
if (judge(a[i].x,a[i].y)) continue;
if (judge(a[i].y,a[i].x)) res+=a[i].w;
else return;
}
#undef judge
ans=min(ans,res);
}
int main()
{
n=read();
for (int i=;i<=n;i++)
a[i].x=read(),a[i].y=read(),a[i].w=read();
for (int i=;i<=n;i++)
if (a[i].x<a[i].y)
{
lx=min(lx,a[i].x);
ly=min(ly,a[i].y);
rx=max(rx,a[i].x);
ry=max(ry,a[i].y);
}
else
{
lx=min(lx,a[i].y);
ly=min(ly,a[i].x);
rx=max(rx,a[i].y);
ry=max(ry,a[i].x);
}
solve(lx,ly,rx,ry),solve(lx,ly,ry,rx);
solve(ly,lx,rx,ry),solve(ly,lx,ry,rx);
write(2ll*(rx+ry-lx-ly)),Wb,write(ans);
}
上一篇:SpringBoot ( 八 ) :RabbitMQ 详解


下一篇:MySQL 修改最大连接数