P2066 机器分配

题面

题目背景

题目描述

总公司拥有高效设备 \(M\) 台,准备分给下属的 \(N\) 个分公司。各分公司若获得这些设备,可以为国家提供一定的盈利。问:如何分配这 \(M\) 台设备才能使国家得到的盈利最大?求出最大盈利值。其中 \(M \leq 15, N \leq 10\) 。分配原则:每个公司有权获得任意数目的设备,但总台数不超过设备数 \(M\) 。

输入输出格式

输入格式:

第一行有两个数,第一个数是分公司数 \(N\) ,第二个数是设备台数 \(M\) 。

接下来是一个 \(N*M\) 的矩阵,表明了第 \(I\) 个公司分配 \(J\) 台机器的盈利。

输出格式:

第 \(1\) 行为最大盈利值

第 \(2\) 到第 \(n\) 为第 \(i\) 分公司分 \(x\) 台

\(P.S.\) 要求答案的字典序最小

输入输出样例

输入样例:

3 3
30 40 50
20 30 50
20 25 30

输出样例:

70
1 1
2 1
3 1

思路

设计 \(dp[i]\) 表示分配 \(i\) 台机器后能获得的最大盈利,定义 \(a[i][j]\) 为 \(i\) 公司在得到 \(j\) 台机器后能获得的利益,那么就有:

\[dp[i]=max \{ dp[i-k]+a[j][k](j \in [1,n],i \in [1,m]) \}
\]

代码实现的话可以这样写:

for(int i=1;i<=n;i++)
for(int j=m;j>=0;j--)
for(int k=j;k>=0;k--)
dp[j]=max(dp[j],dp[j-k]+a[i][k]);

这样我们就能解决第一个问题。

那如何解决第二个问题呢?我们可以再定义一个变量 \(way[i][j]\) 表示分配出 \(i\) 台机器并得到最优解时第 \(j\) 家公司应该被分配 \(way[i][j]\) 台机器,那么每当 \(dp[i]\) 被更新时我们就需要来更新 \(way\) :

for(int i=1;i<=n;i++)
for(int j=m;j>=0;j--)
for(int k=j;k>=0;k--)
if(dp[j]<dp[j-k]+a[i][k])
dp[j]=dp[j-k]+a[i][k],way[j][i]=k;

等会!题目还有一个要求我们没有管:

\(P.S.\) 要求答案的字典序最小

实际上,我们这样更新时,因为是从前往后更新,所以本身就是按照字典序来更新的,所以就不用再管了。而得到题目要求的解时,我们就可以这样操作了:

for(int i=n;i;i--) ans[i]=way[m][i],m-=way[m][i];

接下来输出 \(ans\) 数组就好啦。

AC代码

#include<bits/stdc++.h>
using namespace std;
int n,m,a[20][20],dp[20],way[20][20],ans[20];
int read()
{
int re=0;
char ch=getchar();
while(!isdigit(ch)) ch=getchar();
while(isdigit(ch)) re=(re<<3)+(re<<1)+ch-'0',ch=getchar();
return re;
}
int main()
{
n=read(),m=read();
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
a[i][j]=read();
for(int i=1;i<=n;i++)
for(int j=m;j>=0;j--)
for(int k=j;k>=0;k--)
if(dp[j]<dp[j-k]+a[i][k])
dp[j]=dp[j-k]+a[i][k],way[j][i]=k;
printf("%d",dp[m]);
for(int i=n;i;i--) ans[i]=way[m][i],m-=way[m][i];
for(int i=1;i<=n;i++) printf("\n%d %d",i,ans[i]);
return 0;
}

Luogu P2066 机器分配(dp)的更多相关文章

  1. luogu P2066 机器分配[背包dp+方案输出]

    题目背景 无 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15 ...

  2. P2066 机器分配 DP

    题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...

  3. luogu P2066 机器分配

    题目背景 无 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15 ...

  4. 【线型DP】洛谷P2066 机器分配

    [线型DP]洛谷P2066 机器分配 标签(空格分隔): 线型DP [题目] 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配 ...

  5. CJOJ 1131 机器分配 / Luogu 2066 机器分配 (动态规划)

    CJOJ 1131 机器分配 / Luogu 2066 机器分配 (动态规划) Description Luogu: 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国 ...

  6. P2066 机器分配 解析

    小日记: 1.今天新学的字体颜色,尽管不熟悉,但玩的666,卡星(开心) ╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮ 2.今天油腔滑调,谅解亿下 P2066 ...

  7. 洛谷 p2066 机器分配(资源型)

    机器分配 https://www.luogu.org/problem/show?pid=2066 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定 ...

  8. P2066 机器分配 (DP+DP输出)

    题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...

  9. [洛谷P2066]机器分配

    题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...

随机推荐

  1. selenium基础(窗口截图)

    窗口截图 目的:当脚本执行出错时对当前窗口进行截图 方法:get_screenshot_as_file() #打开百度首页,搜索“selenium",完成后进行截图,并将结果保存至D:/te ...

  2. 解决Pycharm无法导入包问题 Unresolved reference

    在pycharm中设置source路径 file–>setting–>project:server–>project structure 将放package的文件夹设置为source ...

  3. 创建vue项目及引入插件

    部署开发环境 安装淘宝镜像 npm install -g cnpm --registry=https://registry.npm.taobao.org 安装webpack cnpm install ...

  4. 如何玩转跨库Join?跨数据库实例查询应用实践

    背景 随着业务复杂程度的提高.数据规模的增长,越来越多的公司选择对其在线业务数据库进行垂直或水平拆分,甚至选择不同的数据库类型以满足其业务需求.原本在同一数据库实例里就能实现的SQL查询,现在需要跨多 ...

  5. OCCT 7.4.0 beta version is available

    OpenCASCADE 7.4.0测试版本发布 OCC在9月16号发布了opencascade740 beta测试版本,新版本里面做了如下一些重点修改如下: 造型算法部分主要对网格化算法BRepMes ...

  6. Python学习day40-并发编程(终)

    figure:last-child { margin-bottom: 0.5rem; } #write ol, #write ul { position: relative; } img { max- ...

  7. Python 中的运算符

    1.算数运算符 + 加 - 减 * 乘 计算字符串重复的次数 print("唯美" * 10) / 除 round(10/3, 4)   4代表位数 // 取整数 % 取余数 ** ...

  8. HandlerInterceptorAdapter或HandlerInterceptor的使用

    Spring拦截器 HandlerInterceptorAdapter需要继承,HandlerInterceptor需要实现 可以作为日志记录和登录校验来使用 建议使用HandlerIntercept ...

  9. windwos API 第七篇 分离路径,组合路径 _splitpath _makepath

    函数原型: //Break a path name into components. void _splitpath( const char *path, char *drive, char *dir ...

  10. locate,find,df,mount,du命令

    1.locate找数据的时候,相当于去这个数据库里面查(locate查找的时候不扫描磁盘)查找图标文件:locate .icolocat -i 不区分大小写创建一个文件,该文件没有在数据库中,要想在数 ...