P2066 机器分配 解析
小日记:
1、今天新学的字体颜色,尽管不熟悉,但玩的666,卡星(开心)
╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮
2、今天油腔滑调,谅解亿下
题目
总公司拥有高效设备\(M\)台,准备分给下属的\(N\)个分公司。各分公司若获得这些设备,可以为国家提供一定的盈利。问:如何分配这\(M\)台设备才能使国家得到的盈利最大?
求出最大盈利值。其中\(M≤15,N≤10\)。
分配原则:每个公司有权获得任意数目的设备,但总台数不超过设备数M。
输入
第一行有两个数,第一个数是分公司数\(N\),第二个数是设备台数M。
接下来是一个\(N*M\)的矩阵,表明了第 \(I\)个公司分配 \(J\)台机器的盈利。
输出
第1行为最大盈利值
第2到第n为第i分公司分x台
\(P.S.\) 要求答案的字典序最小(为后文埋下伏笔)
样例
解析
设\(f[i][j]\)为前\(i\)个公司总共分配\(j\)台机器的最大利润。对于第\(i\)家子公司,我们可以给其分配的机器台数为:\(1-m\)
所以在该区间内枚举一个值k,状态转移方程即为:
\(f[i][j]=max(f[i-1][j-k],f[i][j])\)
那么,如何处理方案输出问题呢?
我们设\(path[i][j][h]\)对于前i个公司共分配\(j\)台机器的最优方案,第\(h\)个公司应分配多少台机器,当状态发生转移时,更新\(path\)数组即可。最终的答案就存放在\(path[n][m][i]\)之中。
代码如下
#include <bits/stdc++.h>
using namespace std;
int a[25][25];
int f[25][25];
int path[25][25][25];
int n,m;
int main(){
scanf("%d%d",&n,&m);
for (int i=1;i<=n;i++){
for (int j=1;j<=m;j++){
scanf("%d",&a[i][j]);
}
}
for (int i=1;i<=n;i++)
for (int j=1;j<=m;j++)
for (int k=0;k<=j;k++){
if (f[i][j]<f[i-1][j-k]+a[i][k]){
f[i][j]=f[i-1][j-k]+a[i][k];
for (int l=1;l<i;l++)
path[i][j][l]=path[i-1][j-k][l];
path[i][j][i]=k;
}
}
printf("%d\n",f[n][m]);
for (int i=1;i<=n;i++)printf("%d %d\n",i,path[n][m][i]);
return 0;
}
巴特(But),you only have 90 分的好成绩
Why???
回到题面,我们会发现小小的一行字,人畜无害的鸭子(样子)
>(' )
)/
/( <---鸭子
/ `----/
\ ~=- /——:
要求答案的字典序最小
顿时,我***********
辣么,如何使字典序最小呢?这需要我们倒着枚举。
设方程式表示的意思为“不给”第i家公司k台机器(k的值域同上)
注意:并不是\(f\)的意思
那么状态转移方程需改为:
f[i][j]=max(f[i][k],f[i-1][k]+graph[i][j-k]);
再根据这个,对于path数组的更新操作进行一些微调,即可得到满分程序了:
#include <bits/stdc++.h>
using namespace std;
int a[25][25];
int f[25][25];
int path[25][25][25];
int n,m;
int main(){
scanf("%d%d",&n,&m);
for (int i=1;i<=n;i++){
for (int j=1;j<=m;j++){
scanf("%d",&a[i][j]);
}
}
for (int i=1;i<=n;i++)
for (int j=1;j<=m;j++)
for (int k=0;k<=j;k++){
if (f[i][j]<f[i-1][k]+a[i][j-k]){
f[i][j]=f[i-1][k]+a[i][j-k];
for (int l=1;l<i;l++)
path[i][j][l]=path[i-1][k][l];
path[i][j][i]=j-k;
}
}
printf("%d\n",f[n][m]);
for (int i=1;i<=n;i++)printf("%d %d\n",i,path[n][m][i]);
return 0;
}
P2066 机器分配 解析的更多相关文章
- Luogu P2066 机器分配(dp)
P2066 机器分配 题面 题目背景 无 题目描述 总公司拥有高效设备 \(M\) 台,准备分给下属的 \(N\) 个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这 \(M\ ...
- 【线型DP】洛谷P2066 机器分配
[线型DP]洛谷P2066 机器分配 标签(空格分隔): 线型DP [题目] 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配 ...
- 洛谷 p2066 机器分配(资源型)
机器分配 https://www.luogu.org/problem/show?pid=2066 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定 ...
- P2066 机器分配 DP
题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...
- [洛谷P2066]机器分配
题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...
- luogu P2066 机器分配[背包dp+方案输出]
题目背景 无 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15 ...
- P2066 机器分配
题目背景 无 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15 ...
- 洛谷 P2066 机器分配
题目背景 Background 无 题目描述 Description 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能 ...
- P2066 机器分配 (DP+DP输出)
题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...
随机推荐
- FastAPI 学习之路(十四)响应模型
系列文章: FastAPI 学习之路(一)fastapi--高性能web开发框架 FastAPI 学习之路(二) FastAPI 学习之路(三) FastAPI 学习之路(四) FastAPI 学习之 ...
- 使用固件库点亮led灯
1. 项目 使用STM32F103VE的固件库实现流水灯设计. 2. 代码 由于这是基于野火的视频进行学习的,项目代码在上节基础上进行编写的. 点亮绿灯: main.c #include " ...
- [对对子队]会议记录4.12(Scrum Meeting 3)
今天已完成的工作 朱骏豪 工作内容:找到了游戏的背景场景,用PS扣了按钮的图 相关issue:实现UI的美术需求 实现游戏场景中的必要模型 梁河览 工作内容:将关卡选择界面和欢迎界面导入项 ...
- elasticsearch基于RBAC认证和集群之间的TLS通讯
elasticsearch基于RBAC认证和集群之间的TLS通讯 一.背景 二.需要解决的问题 三.给es增加用户名和密码访问 1.修改config/elasticsearch.yml 2.访问es集 ...
- spring cloud zuul的回退
当我们使用 @EnableZuulProxy 注解来开启zuul的路由时,默认在@EnableZuulProxy注解上就包含了@EnableCircuitBreaker注解,即开启了断路器功能.那么在 ...
- 主仆见证了 Hobo 的离别 题解
前言: 题面挺神仙.反正我考试的时候看了40分钟也没看懂. 后来改题感觉自己写的挺假,没想到加个\(k==1\)的特判竟然就A了?无语力. 解析: 看懂题以后就好说了.首先这显然是一个树形结构.我们考 ...
- Machine learning(2-Linear regression with one variable )
1.Model representation Our Training Set [训练集]: We will start with this ''Housing price prediction'' ...
- 电脑cmd命令快速查看连接过的WIFI密码信息
只是突然发现,好奇心作怪,试了一下,妈妈再也不用担心我忘记家里的wifi密码了 1.直接打开"运行"(win键+R) 2.输入CMD 确定 3.输入下面cmd命令.鼠标粘贴 for ...
- 通用 Makefile(及makefile中的notdir,wildcard和patsubst)
notdir,wildcard和patsubst是makefile中几个有用的函数,以前没留意过makefile中函数的用法,今天稍微看看~ 1.makefile里的函数 makefile里的函数使用 ...
- filter tools
// 过滤商品分类 Vue.filter("cateFilter", (data) => { let tmp = ["一级分类", "二级分 ...