思路:

直接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;
}

最新文章

  1. 使select文本框可编辑可选择(jQuery插件)
  2. node.js 初体验
  3. error: No resource identifier found for attribute ‘backIcon’ in package
  4. Flex 日志管理
  5. C-Free 5.0编译失败问题解决办法
  6. Linux 绝对路径与相对路径
  7. Java进阶(三十八)快速排序
  8. Linux下进程通信之管道
  9. 课堂小记---html
  10. QT | 一些学习心得
  11. ELK-Elasticsearch 安装启动
  12. 将python文件打包成exe可运行文件
  13. spring中获取当前项目的真实路径
  14. Gym - 100085G - GCD Guessing Game
  15. 深入研究sqlalchemy连接池
  16. C++MFC编程笔记day05 文档类-单文档和多文档应用程序
  17. Eolinker API 接口文档神器
  18. win10无法访问局域网共享文件?(因微软账户和本地账户登陆问题导致)
  19. 问答项目---金币经验奖励规则及网站配置写入config文件
  20. EF Core 2.1 Raw SQL Queries (转自MSDN)

热门文章

  1. Jquery获取元素的位置
  2. 位运算求最值 学习笔记 (待补充QAQ)
  3. 《javascript算法--对象的比较》
  4. vue:Group XSwitch Actionsheet,Toast控件使用
  5. java-mybaits-011-mybatis-拦截器计算耗时
  6. POJ1426:Find The Multiple(算是bfs水题吧,投机取巧过的)
  7. 一个新人对于DW标签的理解
  8. 浏览器测试string是否为图片
  9. linux下安装vsftp(二)
  10. python yield yield from