【题解】SOFTWARE 二分+搜索/dp
题目描述
一个软件开发公司同时要开发两个软件,并且要同时交付给用户,现在公司为了尽快完成这一任务,将每个软件划分成m个模块,由公司里的技术人员分工完成,每个技术人员完成同一软件的不同模块的所用的天数是相同的,并且是已知的,但完成不同软件的一个模块的时间是不同的,每个技术人员在同一时刻只能做一个模块,一个模块只能由一个人独立完成而不能由多人协同完成。一个技术人员在整个开发期内完成一个模块以后可以接着做任一软件的任一模块。写一个程序,求出公司最早能在什么时候交付软件。
输入输出格式
输入格式:
输入文件第一行包含两个由空格隔开的整数n和m,接下来的n行每行包含两个用空格隔开的整数d1和d2,d1表示该技术人员完成第一个软件中的一个模块所需的天数,d2表示该技术人员完成第二个软件中的一个模块所需的天数。
输出格式:
输出文件仅有一行包含一个整数d,表示公司最早能于d天后交付软件。
输入输出样例
输入样例#1: 复制
3 20
1 1
2 4
1 6
输出样例#1: 复制
18
说明
1<=n<=100,1<=m<=100。 1<= d1,d2<=100。
思路
- 最大值最小(要求做得最慢的人越早做完),因此想到二分
dp
- 设mid天后交付;
- $f[i][j]$表示当前i个人共完成了j个模块一时,还能完成多少个模块二
- 设第i个人完成了k个模块一,则在剩下的时间内他还可以完成$(mid-k*d1[i])/d2[i]$个模块二
- 可以得到转移方程
$$f[i][j]=max(f[i][j],f[i-1][j-k]+((mid-k*d1[i])/d2[i]))$$
- 最后检验计较$f[n][m]$与m大小(当n个人完成了m个模块一时,能否完成m个模块二)
搜索
- 设mid天后交付;
- 按人员编号进行搜索,用lft[0],lft[1]表示还有几个模块一,模块二需要完成
- 枚举第i个人做了几个模块一,在通过$(mid-k*d1[i])/d2[i]$算出可以在剩下几天内在做几个模块二
- lft[0],lft[1]分别减去第i个人完成的模块一,二数量=>进行下一个人的搜索
- 当i=n时,自然剩下所有的未完成的lft[0],lft[1]都要他完成
- 计算此时$d1[i]*lft[0]+d2*lft[1]$的大小与mid的关系
这个二分的DFS检验其实是可以记忆化的,如果是成功的就直接退出了,但是不成功的没有退出,但是会重复计算,比如前3个人,模块一还剩下3个,模块二剩下4个,这个f(3,3,4)可能由很多的状态扩展过来,因此会有很多重复计算,不过要记得每次检验之前要清空f
- 可以用$f[cnt][lft[0]][lft[1]]$记下此方案是否可行,下次再搜到就直接
return false
代码
#include<cmath>
#include<cstdio>
#include<string>
#include<cstring>
#include<iostream>
#include<algorithm>
#define re register int
using namespace std;
inline int read(){
int x=0,w=1;
char ch=getchar();
while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
if(ch=='-') w=-1,ch=getchar();
while(ch>='0'&&ch<='9') x=(x<<1)+(x<<3)+ch-48,ch=getchar();
return x*w;
}
int lft[2]; //还有多少模块要完成
int a1[1000],a2[1000];
int mid,n,m;
char f[110][110][110];
bool chek(int cnt) { //cnt--人
if (f[cnt][lft[1]][lft[2]]) return false; //表示前cnt个人 剩下lef[1] 和lef[2]时不可行
if (cnt==n) {
if (lft[1]*a1[cnt]+lft[2]*a2[cnt] <= mid)
return true;
else {
f[cnt][lft[1]][lft[2]]=true;
return false;
}
}
for (re i=0;i*a1[cnt]<=mid&&i<=lft[1];i++) {
int j=(mid-i*a1[cnt])/a2[cnt]; //可做的a2数
if (j>lft[2]) j=lft[2];
lft[1]-=i;
lft[2]-=j;
if (chek(cnt+1)) return true;
lft[1]+=i;
lft[2]+=j;
}
f[cnt][lft[1]][lft[2]] = true;
return false;
} int main() {
freopen("T21331.in","r",stdin);
freopen("T21331.out","w",stdout);
n=read(),m=read();
for (re i=1;i<n+1;i++){
a1[i]=read();
a2[i]=read();
}
if (n == 1) { printf("%d",m*a1[1]+m*a2[1]); return 0; }
int cnt=0;
int r=min(max(m*a1[2],m*a2[1]),max(m*a1[1],m*a2[2]));
int ans=0x7f7f7f7f;
while (cnt<=r) {
mid=(cnt+r)>>1;
lft[1]=m;
lft[2]=m;
memset(f,0,sizeof f);
if (chek(1)){
ans=min(mid,ans);
ans = mid;
r=mid-1;
}
else cnt=mid+1;
}
printf("%d",ans);
return 0;
}
搜索
#include<cmath>
#include<cstdio>
#include<string>
#include<cstring>
#include<iostream>
#include<algorithm>
#define re register int
using namespace std;
const int inf=2147483647;
const int N=110;
inline int read(){
int x=0,w=1;
char ch=getchar();
while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
if(ch=='-') w=-1,ch=getchar();
while(ch>='0'&&ch<='9') x=(x<<1)+(x<<3)+ch-48,ch=getchar();
return x*w;
}
int f[N][N],d[N][2],n,m,t;
int main() {
freopen("T21331.in","r",stdin);
freopen("T21331.out","w",stdout);
re i,j,k;
n=read(),m=read();
for(i=1;i<=n;++i) d[i][0]=read(),d[i][1]=read();
int l=0,r=100000;
int mid;
while (l<r) {
mid=(l+r)>>1;
for(i=0;i<=n;++i) for(j=0;j<=m;++j) f[i][j]=-inf;
f[0][0]=0;
for(i=1;i<=n;++i)
for(j=0;j<=m;++j)
for(k=0;k<=min(j,mid/d[i][0]);++k)
f[i][j]=max(f[i][j],f[i-1][j-k]+(mid-d[i][0]*k)/d[i][1]);
if(f[n][m]>=m) r=mid;
else l=mid+1;
}
printf("%d",l);
return 0;
}
dp
【题解】SOFTWARE 二分+搜索/dp的更多相关文章
- Poj 1973 Software Company(二分+并行DP)
题意:软件公司接了两个项目,来自同一个合同,要一起交付.该公司有n个程序猿来做这两个项目A和B,每个项目都被分为m个子项目,给定每个程序猿做一个A中的子项目需要的时间Xi秒,和做B中的子项目所需时间Y ...
- 【题解】hdu 3586 Information Disturbing 二分 树形dp
题目描述 Information DisturbingTime Limit: 6000/3000 MS (Java/Others) Memory Limit: 131072/65536 K (Java ...
- (四连测)滑雪场的高度差题解---二分 + 搜索---DD(XYX)的博客
滑雪场的高度差 时间限制: 1 Sec 内存限制: 128 MB 题目描述 滑雪场可以看成M x N的网格状山地(1 <= M,N <= 500),每个网格是一个近似的平面,具有水平高度 ...
- 8VC Venture Cup 2016 - Final Round D. Preorder Test 二分 树形dp
Preorder Test 题目连接: http://www.codeforces.com/contest/627/problem/D Description For his computer sci ...
- POJ3208 Apocalypse Someday(二分 数位DP)
数位DP加二分 //数位dp,dfs记忆化搜索 #include<iostream> #include<cstdio> #include<cstring> usin ...
- CF360B Levko and Array (二分查找+DP)
链接:CF360B 题目: B. Levko and Array time limit per test 2 seconds memory limit per test 256 megabytes i ...
- HDU 5682 zxa and leaf 二分 树形dp
zxa and leaf 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5682 Description zxa have an unrooted t ...
- hihocoder #1301 : 筑地市场 二分+数位dp
#1301 : 筑地市场 题目连接: http://hihocoder.com/problemset/problem/1301 Description 筑地市场是位于日本东京都中央区筑地的公营批发市场 ...
- 【bzoj5174】[Jsoi2013]哈利波特与死亡圣器 二分+树形dp
题目描述 给你一棵以1为根的有根树,初始除了1号点为黑色外其余点均为白色.Bob初始在1号点.每次Alice将其中至多k个点染黑,然后Bob移动到任意一个相邻节点,重复这个过程.求最小的k,使得无论B ...
随机推荐
- 获取汉字首字母并分组排列 PHP
1.代码class Character{ /** * 数组根据首首字母排序 */ /** * 二维数组根据首字母分组排序 * @param array $data 二维数组 * @param stri ...
- 如何在centos上配置802.1Q VLAN标记,linux单网卡多vlan多网段Ip配置案例
介绍 VLAN使将大型网络分成较小且易于管理的网络成为可能.802.1Q是所有供应商都在其网络设备中实施的标准.某些交换机能够将多个VLAN分配给单个网络端口.使用此功能,您可以将多个VLAN分配给单 ...
- GDI编程基础
窗口和视口 视口是基于设备的采用的是设备坐标(单位:像素),窗口是基于程序的采用的是逻辑坐标(单位:像素/毫米/厘米等). 在默认的映射模式下,视口是与窗口等同的.但是如果改变其映射模式,则其对应的单 ...
- Taro使用多线程Worker相关问题解决
JavaScript 语言采用的是单线程模型,HTML5标准中的Web Worker ,为 JavaScript 创造多线程环境.微信小程序也有相应的Worker,同样具备多线程运行的能力 主页面中创 ...
- [刷题] PTA 03-树3 Tree Traversals Again
用栈实现树遍历 1 #include<stdio.h> 2 #include<string.h> 3 #define MAXSIZE 30 4 5 int Pre[MAXSIZ ...
- Xshell 远程使用vim打开文件不能使用右键复制粘贴(右键显示可视)的问题
Xshell 远程使用vim打开文件不能使用右键复制粘贴(右键显示可视)的问题 Debian9.4系统不能再VIM打开文件界面不能使用右键复制粘贴 root@debian:~# vim /usr/sh ...
- crontab简单使用手册
Linux定时任务(1)- crontab 枫林风雨关注 0.1682018.12.14 12:29:47字数 946阅读 921 执行定时任务 crontab 执行循环任务 at 执行一次性任务 c ...
- 所有的 Unix Like 系统都会内建 vi 文书编辑器。vim 是vi的升级版本,它不仅兼容vi的所有指令 ,而且还有一些新的特性在里面。
所有的 Unix Like 系统都会内建 vi 文书编辑器.vim 是vi的升级版本,它不仅兼容vi的所有指令 ,而且还有一些新的特性在里面. https://blog.csdn.net/carolz ...
- VMware安装RedHat7、CentOS7后无网卡解决办法
由于Vmware虚拟网卡和linux兼容问题导致驱动无法正常安装,默认的网卡类型不兼容找到我们的Vmware虚拟机文件夹,将VMware 虚拟机配置 (.vmx),追加一条设置,网卡类型etherne ...
- 阿里云轻量服务器价格及轻量与ECS服务器区别比较
https://yq.aliyun.com/articles/221647 摘要: 阿里云轻量应用服务器价格表及介绍,关于轻量应用服务器和ECS服务器的性能对比 阿里云轻量应用服务器是阿里云新推出的服 ...