做题记录:SP703 SERVICE - Mobile Service

SERVICE - Mobile Service

暴力

fi,a,b,c 表示处理完前 i 个任务,第一个人在 a 位置,第二个人在 b 位置,第三个人在 c 位置的最小代价。

方程:

fi,a,b,c=minfi1,a,b,c+c(a,a),fi1,a,b,c+c(b,b),fi1,a,b,c+c(c,c)

微微优化

fi,a,b 表示处理完前 i 个任务,一个人在 Xi 剩下两个人在 a,b 的最小代价。

for(int j = 1 ;j <= n; ++i) {
	for(int i = j + 1, i <= n; ++i) {
		if(a[i] > a[j]) {
			f[j] = max(f[j] + 1, f[i]);
		}
	}
}
for(int i = 2; i <= n; ++i) {
	for(int j = 1; j <= i - 1; ++j) {
		if(a[j] < a[i]) {
			f[i] = max(f[i], f[j] + 1);
		}
	}
}

考虑状态转移方程:

  1. a -> xi+1
  2. b -> xi+1
  3. xi -> xi+1

fi+1,xi,b=max(fi+1,xi,b,fi,a,b+c(a,xi+1))

fi+1,xi,a=max(fi+1,xi,a,fi,a,b+c(b,xi+1))

posted @   lyfandlzf  阅读(4)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
点击右上角即可分享
微信分享提示