搬寝室
来源:互联网 发布:东汉国力 知乎 编辑:程序博客网 时间:2024/04/28 05:43
看见这题目就笑了,不是和上次那题一样的思路吗,只是从最大变成了最小,还有初始化也有不同。
dp[i][j]=min(dp[i ][j - 1],dp[i-1][j-2]+d[j]);
i代表取的次数,j代表个数。
其中d[]数组代表的是这个数和前一个数的差的平方,这样这个数与前一个的差方和后一个数的差方都可以表示出来且不重复,就是记录一下值而已。还有,物品要先排序。
#include<iostream>#include<cstdio>#include<cstring>#include<algorithm>using namespace std;long long a[2005], d[2005];long long dp[1005][2005];long long min(long long a, long long b){return a < b ? a : b;}bool cmp(long long a, long long b){return a < b;}int main(){int i, j, m, n, k;long long ans, sum;while (scanf("%d%d", &n, &k) != EOF){for (i = 1; i <= n; i++)cin >> a[i];sort(a + 1, a + 1 + n, cmp);d[0] = d[1] = 0; j = 0;for (i = 2; i <=n; i++){d[i] = (a[i] - a[i - 1])*(a[i] - a[i - 1]);}dp[1][0] = dp[1][1] = 0;dp[1][2] = d[2];for (i = 3; i <= n; i++){dp[1][i] = min(dp[1][i - 1], d[i]);}for (i = 2; i <= k; i++){for (j = 2 * i; j <= n; j++){if (j == 2 * i)dp[i][j] = dp[i - 1][j - 2] + d[j];elsedp[i][j] = min(dp[i][j - 1], dp[i - 1][j - 2] + d[j]);}}//for (i = 1; i <= k; i++)//{//for (j = 1; j <= n; j++)//cout << dp[i][j] << " ";//cout << endl;//}//for (i = 1; i <= n; i++)//cout << d[i] << " ";//cout << endl;cout << dp[k][n] << endl;}return 0;}
0 0
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 搬寝室
- 即将搬寝室(图)
- 黑马程序员_面向对象2
- java单例模式的讨论
- Android中常常使用shape来定义控件的一些显示属性
- Visual Studio 2012本身都是已经支持Jquery/Javascript智能提示
- Java中常见的集合容器类关系图
- 搬寝室
- 上门洗车APP --- Android客户端开发 前言及业务简介
- GUI--Swing组件(2)
- 学习笔记6.8
- eclipse常用快捷键
- 黑马day05 session实现防止重复提交&小案例
- Hibernate实体关系映射——双边的一对一关系
- 2015061907 - firebug安装和下载(3)
- 学习笔记6.9