码迷,mamicode.com
首页 > 其他好文 > 详细

BZOJ 1096 ZJOI2007 仓库建设 边坡优化

时间:2015-09-23 20:58:20      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:

标题效果:特定n植物,其中一些建筑仓库,有一点使,假设没有仓库仓库向右仓库。最低消费要求

非常easy边坡优化……在此之前刷坡优化的情况下,即使这道题怎么错过

订购f[i]作为i点建设化妆i花费所有安置前的最低货

那里

技术分享

公式编辑器就是爽啊~

令sump[i]为p[i]的前缀和
令sumxp[i]为p[i]*x[i]的前缀和

化简有

f[j] + sumxp[j] = x[i]*sump[j] + sumxp[i] - x[i]*sump[i] - C[i] + f[i]

当中

X[j]=sump[j]
Y[j]=f[j]+sumxp[j]
s[i]=x[i]
维护下凸包

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define M 1001001
using namespace std;
typedef long long ll;
typedef pair<ll,ll> abcd;
int n,X[M],P[M],C[M];
ll sumP[M],sumXP[M],f[M];
abcd q[M];int r,h;
double Get_Slope(const abcd &x,const abcd &y)
{
	return (double)(x.second-y.second)/(x.first-y.first);
}
void Insert(abcd x)
{
	while(r-h>1)
	{
		if( Get_Slope(q[r],x)<Get_Slope(q[r-1],q[r]) )
			q[r--]=q[0];
		else
			break;
	}
	q[++r]=x;
}
abcd Get_Ans(double s)
{
	while(r-h>1)
	{
		if(Get_Slope(q[h+1],q[h+2])<s)
			q[++h]=q[0];
		else
			break;
	}
	return q[h+1];
}
int main()
{
	int i;
	cin>>n;
	for(i=1;i<=n;i++)
		scanf("%d%d%d",&X[i],&P[i],&C[i]);
	for(i=1;i<=n;i++)
	{
		sumP[i]=sumP[i-1]+P[i];
		sumXP[i]=sumXP[i-1]+(ll)X[i]*P[i];
	}
	for(i=1;i<=n;i++)
	{
		Insert( make_pair(sumP[i-1],f[i-1]+sumXP[i-1]) );
		abcd p=Get_Ans(X[i]);
		f[i] = p.second + X[i]*sumP[i] - X[i]*p.first - sumXP[i] + C[i] ;
	}
	cout<<f[n]<<endl;
}


版权声明:本文博主原创文章,博客,未经同意不得转载。

BZOJ 1096 ZJOI2007 仓库建设 边坡优化

标签:

原文地址:http://www.cnblogs.com/lcchuguo/p/4833273.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!