http://acm.hdu.edu.cn/showproblem.php?pid=3480

将一列数划分成几个集合,这些集合的并集为该数列,求每个数列的(最大值-最小值)^2的和的最小值。

简单的dp都会写,就不讲了。

然后就是四边形优化了,参考:https://blog.csdn.net/noiau/article/details/72514812

事实上四边形优化的条件一般是靠打表打出来的。

于是简单记录下吧:

先排序。

设dp[i][j]为前j个数划分成i个集合的最小值,cost[i][j]为i~j的集合价值。

显然有dp[i][j]=min{dp[i][j],dp[i][k]+cost[k+1][j]}

接着打表得出(就是打一个矩阵,观察矩阵每行每列都是递增的):

s[i-1][j]<=s[i][j]<=s[i][j+1]

然后就可以利用第三条结论来优化了。

(此外能否用四边形不等式优化还和你如何定义dp也是有关系的……我就是被坑了把dp两个状态倒换一下才行。)

还有一些注意事项看一下https://www.cnblogs.com/mlystdcall/p/6525962.html吧。

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<vector>
  4. #include<queue>
  5. #include<cstring>
  6. #include<algorithm>
  7. #include<map>
  8. using namespace std;
  9. const int N=;
  10. const int M=;
  11. const int INF=1e9;
  12. inline int read(){
  13. int X=,w=;char ch=;
  14. while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
  15. while(isdigit(ch))X=(X<<)+(X<<)+(ch^),ch=getchar();
  16. return w?-X:X;
  17. }
  18. inline int sqr(int k){return k*k;}
  19. int a[N],dp[M][N],s[M][N];
  20. int main(){
  21. int t=read();
  22. for(int cas=;cas<=t;cas++){
  23. printf("Case %d: ",cas);
  24. int n=read(),m=read();
  25. for(int i=;i<=n;i++)a[i]=read();
  26. sort(a+,a+n+);
  27. for(int i=;i<=n;i++){
  28. dp[][i]=sqr(a[i]-a[]);
  29. s[][i]=;
  30. }
  31. for(int i=;i<=m;i++){
  32. s[i][n+]=n-;
  33. for(int j=n;j>=i;j--){
  34. dp[i][j]=INF;
  35. for(int k=s[i-][j];k<=s[i][j+];k++){
  36. if(dp[i][j]>dp[i-][k]+sqr(a[j]-a[k+])){
  37. dp[i][j]=dp[i-][k]+sqr(a[j]-a[k+]);
  38. s[i][j]=k;
  39. }
  40. }
  41. }
  42. }
  43. printf("%d\n",dp[m][n]);
  44. }
  45. return ;
  46. }

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

HDU3480:Division——题解的更多相关文章

  1. HDU3480 Division —— 斜率优化DP

    题目链接:https://vjudge.net/problem/HDU-3480 Division Time Limit: 10000/5000 MS (Java/Others)    Memory ...

  2. hdu3480 Division(dp平行四边形优化)

    题意:将n个数分成m段,每段的代价为最大值减最小值的平方,为代价最小是多少n<=10000 ,m<=5000 题解:先拍好序,从小到大,这样绝对是花费最小的,不过怎么样来做呢?一定很容易想 ...

  3. HDU-3480 Division (四边形不等式优化DP)

    题目大意:将n个数分成m组,将每组的最大值与最小值的平方差加起来,求最小和. 题目分析:先对数排序.定义状态dp(i,j)表示前 j 个数分成 i 组得到的最小和,则状态转移方程为dp(i,j)=mi ...

  4. [HDU3480] Division [四边形不等式dp]

    题面: 传送门 思路: 因为集合可以无序选择,所以我们先把输入数据排个序 然后发先可以动归一波 设$dp\left[i\right]\left[j\right]$表示前j个数中分了i个集合,$w\le ...

  5. HDU3480 Division——四边形不等式或斜率优化

    题目大意 将N个数分成M部分,使每部分的最大值与最小值平方差的和最小. 思路 首先肯定要将数列排序,每部分一定是取连续的一段,于是就有了方程 $\Large f(i,j)=min(f(i-1,k-1) ...

  6. CF1444A (1445C)Division 题解

    题意:求最大的正整数 \(x\) ,使 \(x \mid p且q \nmid x\) . 首先,当 \(q \nmid p\) ,显然取 \(x=p\) 是最优解. 现在,我们考虑 \(q \mid ...

  7. hdu3480 Division

    Problem Description Little D is really interested in the theorem of sets recently. There's a problem ...

  8. [Leetcode Week3]Evaluate Division

    Evaluate Division题解 原创文章,拒绝转载 题目来源:https://leetcode.com/problems/evaluate-division/description/ Desc ...

  9. HDU2829 Lawrence —— 斜率优化DP

    题目链接:https://vjudge.net/problem/HDU-2829 Lawrence Time Limit: 2000/1000 MS (Java/Others)    Memory L ...

随机推荐

  1. 微信小程序学习笔记(1)- 按钮触发的函数的定义以及不同页面之间的数据传递

    <view class='item' bindtap='onCountryTab' data-idx='4'> 1)bindtap属性用来设置控件需要绑定的函数,函数用单引号括起来:. 2 ...

  2. APP九宫格滑动解锁的处理

    写手机自动化测试脚本关于APP九宫格滑动解锁方面采用了appium API 之 TouchAction 操作. 先是用uiautomatorviewer.bat查询APP元素坐标: 手工计算九宫格每个 ...

  3. openstack多region介绍与实践---转

    概念介绍 所谓openstack多region,就是多套openstack共享一个keystone和horizon.每个区域一套openstack环境,可以分布在不同的地理位置,只要网络可达就行.个人 ...

  4. 一键部署 Docker Datacenter ---简化docker数据中心安装步骤

    DDC 简介 2016年2月下旬,Docker发布了企业级容器管理和服务部署的整体解决方案平台-Docker Datacenter,简称DDC.DDC 有三个组件构成:1. Docker Univer ...

  5. 学霸系统UI项目功能说明书 v1.0版本

    发布人员:软件工程实践小队. 发布内容:学霸系统UI项目说明书. 版本:学霸v1.0版本. 学霸系统UI项目说明书 v1.0版本分为以下部分: Part 1:用户须知: Part 2:功能实现: Pa ...

  6. 让我们一起来做最漂亮的Android界面吧!

    让我们一起来做最漂亮的Android界面吧! AndroidiOS产品设计 摘要:如何为Android设备量身定制以打造出最为完美的应用?这是让诸多开发者很是头疼的问题.不同于iOS,Android设 ...

  7. 第一章 Java Web应用开发技术

    Java Web应用开发是基于JavaEE(JavaEnterprise Edition)框架的,而JavaEE是建立在Java平台上的企业级应用解决方案.JavaEES框架提供的Web开发技术主要支 ...

  8. Spring Boot(四)@EnableXXX注解分析

    在学习使用springboot过程中,我们经常碰到以@Enable开头的注解,其实早在Spring3中就已经出现了类似注解,比如@EnableTransactionManagement.@ Enabl ...

  9. 关于JS里面写JAVA代码的问题

    最近做项目需要在JS脚本里面调用一个JAVA的函数得到数据,在网上查了很久,发现JS脚本里面不能写JAVA函数.只能把JS脚本里面的代码写进JSP文件里面的<script>标签内,然后写J ...

  10. open-stf 安装篇(linux)

       OpenSTF 百度MTC的远程真机调试 Testin的云真机 腾讯WeTest的云真机 阿里MQC的远程真机租用 什么是OpenSTF? OpenSTF是一个手机设备管理平台,可以对手机进行远 ...