【题目链接】 http://poj.org/problem?id=3709

【题目大意】

  给出一个长度为n个非严格单调递增数列,每次操作可以使得其中任意一项减一,
  问现在使得数列中每项数相同的数的数量都大于等于k-1,问最少进行几次操作

【题解】

  我们设dp[i]为前i项答案,得到方程dp[i]=min(dp[j]+S[i]-S[j]-aj*(i-j)),
  dp[i]=S[i]+min(dp[j]-S[j]+aj*j-aj*i),为关于i的线性函数,
  所以我们对f(y)=-ax*y+dp[x]-S[x]+ax*x进行斜率优化。

【代码】

  1. #include <algorithm>
  2. #include <cstdio>
  3. #include <cstring>
  4. typedef long long LL;
  5. const int MAX_N=500010;
  6. int n,k;
  7. LL a[MAX_N],dp[MAX_N],S[MAX_N],deq[MAX_N];
  8. LL f(int x,int y){return -a[x]*y+dp[x]-S[x]+a[x]*x;}
  9. bool check(int f1,int f2,int f3){
  10. LL a1=-a[f1],b1=dp[f1]-S[f1]+a[f1]*f1;
  11. LL a2=-a[f2],b2=dp[f2]-S[f2]+a[f2]*f2;
  12. LL a3=-a[f3],b3=dp[f3]-S[f3]+a[f3]*f3;
  13. return (a2-a1)*(b3-b2)>=(b2-b1)*(a3-a2);
  14. }
  15. void solve(){
  16. for(int i=0;i<n;i++)S[i+1]=S[i]+a[i];
  17. int s=0,t=1;
  18. deq[0]=0; dp[0]=0;
  19. for(int i=k;i<=n;i++){
  20. if(i-k>=k){
  21. while(s+1<t&&check(deq[t-2],deq[t-1],i-k))t--;
  22. deq[t++]=i-k;
  23. }while(s+1<t&&f(deq[s],i)>=f(deq[s+1],i))s++;
  24. dp[i]=S[i]+f(deq[s],i);
  25. }printf("%lld\n",dp[n]);
  26. }int T;
  27. int main(){
  28. scanf("%d",&T);
  29. while(T--){
  30. scanf("%d%d",&n,&k);
  31. for(int i=0;i<n;i++)scanf("%lld",&a[i]);
  32. solve();
  33. }return 0;
  34. }

POJ 3709 K-Anonymous Sequence(斜率优化DP)的更多相关文章

  1. POJ 3709 K-Anonymous Sequence - 斜率优化dp

    描述 给定一个数列 $a$, 分成若干段,每段至少有$k$个数, 将每段中的数减少至所有数都相同, 求最小的变化量 题解 易得到状态转移方程 $F_i = \min(F_j  + sum_i - su ...

  2. [POJ1180&POJ3709]Batch Scheduling&K-Anonymous Sequence 斜率优化DP

    POJ1180 Batch Scheduling Description There is a sequence of N jobs to be processed on one machine. T ...

  3. POJ 1180 Batch Scheduling(斜率优化DP)

    [题目链接] http://poj.org/problem?id=1180 [题目大意] N个任务排成一个序列在一台机器上等待完成(顺序不得改变), 这N个任务被分成若干批,每批包含相邻的若干任务. ...

  4. poj 1180:Batch Scheduling【斜率优化dp】

    我会斜率优化了!这篇讲的超级棒https://blog.csdn.net/shiyongyang/article/details/78299894?readlog 首先列个n方递推,设sf是f的前缀和 ...

  5. POJ3709 K-Anonymous Sequence 斜率优化DP

    POJ3709 题意很简单 给n个递增整数(n<=500000)和一种操作(选择任意个数 使他们减少整数值) 使得对于所有的整数 在数列中 有k个相等的数 O(n^2)的DP方程很容易得出 如下 ...

  6. poj 1260 Pearls 斜率优化dp

    这个题目数据量很小,但是满足斜率优化的条件,可以用斜率优化dp来做. 要注意的地方,0也是一个决策点. #include <iostream> #include <cstdio> ...

  7. 斜率优化dp(POJ1180 Uva1451)

    学这个斜率优化dp却找到这个真心容易出错的题目,其中要从n倒过来到1的确实没有想到,另外斜率优化dp的算法一开始看网上各种大牛博客自以为懂了,最后才发现是错了. 不过觉得看那些博客中都是用文字来描述, ...

  8. 【转】斜率优化DP和四边形不等式优化DP整理

    (自己的理解:首先考虑单调队列,不行时考虑斜率,再不行就考虑不等式什么的东西) 当dp的状态转移方程dp[i]的状态i需要从前面(0~i-1)个状态找出最优子决策做转移时 我们常常需要双重循环 (一重 ...

  9. BZOJ 1010: [HNOI2008]玩具装箱toy 斜率优化DP

    1010: [HNOI2008]玩具装箱toy Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再 ...

  10. BZOJ 3156: 防御准备 斜率优化DP

    3156: 防御准备 Description   Input 第一行为一个整数N表示战线的总长度. 第二行N个整数,第i个整数表示在位置i放置守卫塔的花费Ai. Output 共一个整数,表示最小的战 ...

随机推荐

  1. Kafka自我学习3-Scalable

    1.After created the zookeeper cluster, we found all broker cluster topic can be find in zoo1, zoo2, ...

  2. linux下输出tomcat控制台信息

    进入tomcat/logs/目录执行命令:tail -f catalina.out即可

  3. 转: 构建基于Nginx的文件服务器思路与实现

    在Web项目中使用独立的服务器来保存文件和图片的好处很多,如:便于统一管理,分流web服务器的压力,可进行访问加速等.另外当web服务器需要做集群进行负载均衡时,图片和文件上传在各个服务器之间同步将是 ...

  4. POJ 1002 487-3279 (map )

    title: 487-3279 map POJ1002 tags: [map] 题目链接 Description Businesses like to have memorable telephone ...

  5. js中typeof 与instanceof的区别

    1.typeof 用来检测给定变量的数据类型,其返回的值是下列某个字符串: "undefined":变量未定义 "boolean":变量为布尔类型 " ...

  6. django unresolved template

    参考:https://stackoverflow.com/questions/8487410/pycharm-django-1-3-static-url-in-templates-unresolved ...

  7. python3 正则表达式re模块

    正则表达式的功能:字符串的模糊匹配查询import re元字符 . ---->匹配除换行符意外的任意字符 ^ ---->匹配行首位置 $ ---->匹配行尾位置 关于重复的元字符 * ...

  8. JAVA -- JDK JRE JAR

    转载:http://blog.csdn.net/wym19830218/article/details/5399401 JDK里面的工具也是用JAVA编写的,它们本身运行的时候也需要一套JRE,如C: ...

  9. SuSE Linux10.1 网络设置以及和主机通信

    SuSE Linux10.1 网络设置以及和主机通信 http://www.cnblogs.com/kevintian/articles/1086994.html 在VMWare上安装好SuSE之后, ...

  10. MySQL 基础内容

    创建数据库 对于表的操作需要先进入库 use 库名: -- 创建一个名为 inana_db 的数据库,数据库字符编码指定为 utf8create database inana_db character ...