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.分 ... 
随机推荐
- SWT图形用户界面之配置
			1.在eclipse的plugins目录下找到org.eclipse.swt.win32.win32.x86_64_3.111.0.v20190605-1801.jar文件 其中3.111.0是ecl ... 
- VM 虚拟机使用桥接模式却连不上网的解决办法(转载)
			只需将VM的虚拟网络编辑器中关于 VMnet0 的设置改一下就行了: 1.进入VMware的 编辑 -> 虚拟网络编辑器. 第一步 2.选择更改设置. 3.将VMnet0(或其它类型为桥接模式的 ... 
- neo4j安装APOC插件
			1.APOC下载地址:https://github.com/neo4j-contrib/neo4j-apoc-procedures/releases/3.4.0.1 只要下载.jar这一个压缩文件就好 ... 
- java_IO流(输入流)
			* 字节输入流(InputStream):所有字节输入流的父类 * 所有子类共性方法: * int read():从输入流中读取数据的下一个字节 * int read(byte[] b):从输入流中拂 ... 
- 在页面上显示PDF
			/// <summary> /// 读取PDF文件 /// </summary> /// <param name="fName">文件名称(可以 ... 
- 2019-8-31-dotnet-特性-DynamicallyInvokable-是用来做什么的
			title author date CreateTime categories dotnet 特性 DynamicallyInvokable 是用来做什么的 lindexi 2019-08-31 16 ... 
- 判断语句(if...else)if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码
			判断语句(if...else) if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码. 语法: if(条件) { 条件成立时执行的代码 } else { 条件不成立时 ... 
- css实现截取文本
			.ellipsis{ max-width: 260px; // 自定义 overflow: hidden; text-overflow: ellipsis; white-space: nowrap; ... 
- 关于Android 的网址
			Android 官方API查询网址 https://developer.android.google.cn/ 第三方镜像Android API查询网址 (比官方浏览速度快一些,缺点现有API较低) h ... 
- MFC编译Freetype2.3.7
			从http://www.freetype.org下载源代码. FreeType2库源码包中包含多种环境与编译器下的make文件,其中还包含vc的项目文件. 我用的是VC,所以首先找到VC环境的项目文件 ... 
