POJ 1260 Pearls (斜率DP)题解
2024-10-12 01:02:13
思路:
直接DP也能做,这里用斜率DP。
dp[i] = min{ dp[j] + ( sum[i] - sum[j] + 10 )*pr[i]} ;
k<j<i => dp[j] - dp[k] <pr[i]*( sum[j] - sum[k] )
再套模板
#include<queue>
#include<cstring>
#include<set>
#include<map>
#include<stack>
#include<cmath>
#include<vector>
#include<cstdio>
#include<iostream>
#include<algorithm>
#define ll long long
const int N = 1000+5;
using namespace std;
int pr[N],sum[N],dp[N],q[N];
int up(int x,int y){
return dp[x] - dp[y];
}
int down(int x,int y){
return sum[x] - sum[y];
}
int main(){
int n,m,T;
scanf("%d",&T);
while(T--){
scanf("%d",&n);
for(int i = 1;i <= n;i++) scanf("%d%d",&sum[i],&pr[i]);
for(int i = 2;i <= n;i++) sum[i] += sum[i-1];
int head,tail;
head = tail = 0;
dp[0] = 0;
q[tail++] = 0;
for(int i = 1;i <= n;i++){
while(head+1 < tail && up(q[head+1],q[head]) <= pr[i]*down(q[head+1],q[head])){
head++;
}
dp[i] = dp[q[head]] + (sum[i] - sum[q[head]] + 10)*pr[i];
while(head + 1 < tail && up(i,q[tail - 1])*down(q[tail - 1],q[tail - 2]) <= up(q[tail - 1],q[tail - 2])*down(i,q[tail - 1])){
tail--;
}
q[tail++] = i;
}
printf("%lld\n",dp[n]);
}
return 0;
}
最新文章
- 使select文本框可编辑可选择(jQuery插件)
- node.js 初体验
- error: No resource identifier found for attribute ‘backIcon’ in package
- Flex 日志管理
- C-Free 5.0编译失败问题解决办法
- Linux 绝对路径与相对路径
- Java进阶(三十八)快速排序
- Linux下进程通信之管道
- 课堂小记---html
- QT | 一些学习心得
- ELK-Elasticsearch 安装启动
- 将python文件打包成exe可运行文件
- spring中获取当前项目的真实路径
- Gym - 100085G - GCD Guessing Game
- 深入研究sqlalchemy连接池
- C++MFC编程笔记day05 文档类-单文档和多文档应用程序
- Eolinker API 接口文档神器
- win10无法访问局域网共享文件?(因微软账户和本地账户登陆问题导致)
- 问答项目---金币经验奖励规则及网站配置写入config文件
- EF Core 2.1 Raw SQL Queries (转自MSDN)