Luogu P2066 机器分配(dp)
题面
题目背景
无
题目描述
总公司拥有高效设备 \(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\) 台机器后能获得的利益,那么就有:
\]
代码实现的话可以这样写:
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)的更多相关文章
- luogu P2066 机器分配[背包dp+方案输出]
题目背景 无 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15 ...
- P2066 机器分配 DP
题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...
- luogu P2066 机器分配
题目背景 无 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15 ...
- 【线型DP】洛谷P2066 机器分配
[线型DP]洛谷P2066 机器分配 标签(空格分隔): 线型DP [题目] 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配 ...
- CJOJ 1131 机器分配 / Luogu 2066 机器分配 (动态规划)
CJOJ 1131 机器分配 / Luogu 2066 机器分配 (动态规划) Description Luogu: 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国 ...
- P2066 机器分配 解析
小日记: 1.今天新学的字体颜色,尽管不熟悉,但玩的666,卡星(开心) ╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮╰( ̄▽ ̄)╮ 2.今天油腔滑调,谅解亿下 P2066 ...
- 洛谷 p2066 机器分配(资源型)
机器分配 https://www.luogu.org/problem/show?pid=2066 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定 ...
- P2066 机器分配 (DP+DP输出)
题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...
- [洛谷P2066]机器分配
题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15,N≤10.分 ...
随机推荐
- css中字体属性的简写
- SwiftUI 实现Draggesture效果
今天闲来无事,使用SwiftUI 实现拖动,并且返回的动态效果.代码不多..... 效果如下: 代码如下: import SwiftUI import Combine class KBDragObje ...
- Linux操作系统系列-Linux基础
概述 先了解下unix,unix是一个多任务.多用户的操作系统,并且是收费的操作系统. 1991年的10月5日,林纳斯·托瓦兹在comp.os.minix新闻组上发布消息,正式向外宣布Linux内核的 ...
- 服务器访问数据库表mysql
服务器的MySQL配置就不说了,直接说一些用到的基础命令 登陆 show databases; use 数据库: show tables; 执行sql即可: 一定要有分号 select * from ...
- 跟我一起使用create-react-app脚手架搭建vw-layout解决方案
之前也是看过大漠的vw适配Vue-cli,我自己写H5,还有使用vue做项目的时候,会搭建大漠博客中的那一套. 现在在github上面,看见了一位博主使用create-react-app也是用vw适配 ...
- AJAX相关概念及应用
1.Ajax(Asynchronous JavaScript And XML) 异步的JavaScript和XML XML 可扩展标记语言 Ajax是常用的WEB开发技术,是联系前端和后端的桥梁 应用 ...
- C++: Type conversions
1.static_cast static_cast可以转换相关联的类,可以从子类转换成父类.也能从父类转向子类,但是如果转换的父类指针(或者父类引用)所指向的对象是完整的,那么是没有问题:但是 ...
- vue_cli 安装
1.安装node 2.cmd node-v3.如果是刚刚安装输入 node-v 会成功出现版本 如果不是全局安装 过段时间输入 node-v会出现 'node' 不是内部或外部命令,也不是可运行的程序 ...
- 学习笔记css3
边框 盒子圆角 border-radius:5px / 20%: border-radius:5px 4px 3px 2px; 左上,右上,右下,左下 盒子阴影 box-shadow:box-shad ...
- bzoj1913: [Apio2010]signaling 信号覆盖
传送门 题解传送门 //Achen #include<algorithm> #include<iostream> #include<cstring> #includ ...