Cats Transport(斜率优化dp)

原题见洛谷。

设f[i][j]表示前i个cs官接走前j只猫,前j只猫等待的最少时间。

设cat[i]表示刚好接到接第i只猫的出发时间,那么cat[i]等于t[i]减去h[i]之前所有路的长度。

把猫按cat排序,设sumt[i]表示前i只猫的cat[i]的和。

现在来分析状态转移方程。

假如第i个cs官接走了第k+1~j只猫,那么f[i][j]=f[i-1][k]+(cat[j]-cat[k+1])+(cat[j]-cat[k+2])+...+(cat[j]-cat[j-1])+(cat[j]-cat[j]) 。

用上sumt,可以得到:f[i][j]=min{f[i-1][k] + cat[j]*(j-k) - (sumt[j]-sumt[k]) }。

去掉min,把关于k的加减项移到左边,关于k的乘除项移到右边,可以得到:

f[i-1][k]+sumt[k] = k*cat[j] + f[i][j] - sumt[k] - cat[j]*j 。

现在就变成了标准的斜率优化dp。由于cat[j]是递增的,所以只需要维护(f[i-1][k]+sumt[k])/k的下凸包,每次取队首即可。

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long LL;
const int MAXN=100005;
const int MAXM=100005;
int N,M,P;
LL f[MAXM],t[MAXN],sumt[MAXM],cat[MAXM];
struct data{int id;LL num;}q[MAXM];

char c;
void scan(int &x)
{
	for(c=getchar();c<'0'||c>'9';c=getchar());
	for(x=0;c>='0'&&c<='9';c=getchar()) x=x*10+c-'0';
}

void scan(LL &x)
{
	for(c=getchar();c<'0'||c>'9';c=getchar());
	for(x=0;c>='0'&&c<='9';c=getchar()) x=x*10+c-'0';
}

int main()
{
	int i,j;
	LL x;
	scan(N);scan(M);scan(P);
	for(i=2;i<=N;i++)
	{
		scan(x);
		t[i]=t[i-1]+x;
	}
	
	for(i=1;i<=M;i++)
	{
		scan(j); scan(x);
		cat[i]=x-t[j];
	}
	
	sort(cat+1,cat+1+M);
	for(i=1;i<=M;i++) sumt[i]=sumt[i-1]+cat[i];
	
	memset(f,0x3f,sizeof(f));
	f[0]=0;
	
	int L,R;
	for(i=1;i<=P;i++)
	{
		L=1; R=1; q[1]=(data){0,0};
		for(j=1;j<=M;j++)
		{
			while(L<R&&cat[j]*(q[L+1].id-q[L].id)>=(q[L+1].num-q[L].num))
				L++;
			while(L<R&&(f[j]+sumt[j]-q[R].num)*(q[R].id-q[R-1].id)<=(q[R].num-q[R-1].num)*(j-q[R].id))
				R--;
			q[++R]=(data){j,f[j]+sumt[j]};
			f[j]=q[L].num-sumt[j]+cat[j]*(j-q[L].id);	
		}
	}
	cout<<f[M];
	return 0;
}

 

展开阅读全文

Python数据分析与挖掘

01-08
92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元   为什么学习数据分析?       人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。       从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。    本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。   二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。   三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。   四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。   五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。
©️2020 CSDN 皮肤主题: 大白 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值