hdoj1412搬寝室
#include<iostream>
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<string.h>
using namespace std;
int n, k;
int w[2000], p[2000][1000]; //w重量,p[i][j]前i个物品中搬j个的最小体力
int main()
{
while (scanf("%d%d", &n, &k) != EOF) {
for (int i = 1; i <= n; ++i)
scanf("%d", w + i);
for (int i = 1; i < n; ++i) //从小到大排序
for (int j = n - 1; j >= i; --j)
if (w[j] > w[j + 1])
swap(w[j], w[j + 1]);
for (int i = 0; i <= n; ++i) //初始化
p[i][0] = 0;
for (int i = 1; i <= k; ++i) //下面会用到的临界值
p[2 * i - 1][i] = 1000000000; //赋值无穷大,这种不可能的情况就不会被选择
for (int i = 2; i <= n; ++i) {
for (int j = 1; j <= i / 2; ++j) {
p[i][j] =
min(p[i - 2][j - 1] +
(w[i] - w[i - 1]) * (w[i] - w[i - 1]),
p[i - 1][j]);
}
}
printf("%d\n", p[n][k]);
}
}
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<string.h>
using namespace std;
int n, k;
int w[2000], p[2000][1000]; //w重量,p[i][j]前i个物品中搬j个的最小体力
int main()
{
while (scanf("%d%d", &n, &k) != EOF) {
for (int i = 1; i <= n; ++i)
scanf("%d", w + i);
for (int i = 1; i < n; ++i) //从小到大排序
for (int j = n - 1; j >= i; --j)
if (w[j] > w[j + 1])
swap(w[j], w[j + 1]);
for (int i = 0; i <= n; ++i) //初始化
p[i][0] = 0;
for (int i = 1; i <= k; ++i) //下面会用到的临界值
p[2 * i - 1][i] = 1000000000; //赋值无穷大,这种不可能的情况就不会被选择
for (int i = 2; i <= n; ++i) {
for (int j = 1; j <= i / 2; ++j) {
p[i][j] =
min(p[i - 2][j - 1] +
(w[i] - w[i - 1]) * (w[i] - w[i - 1]),
p[i - 1][j]);
}
}
printf("%d\n", p[n][k]);
}
}
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
· 对象命名为何需要避免'-er'和'-or'后缀
· SQL Server如何跟踪自动统计信息更新?
· AI与.NET技术实操系列:使用Catalyst进行自然语言处理
· dotnet 源代码生成器分析器入门
· 官方的 MCP C# SDK:csharp-sdk
· 一款 .NET 开源、功能强大的远程连接管理工具,支持 RDP、VNC、SSH 等多种主流协议!
· 一文搞懂MCP协议与Function Call的区别
· 一次Java后端服务间歇性响应慢的问题排查记录