P1281 书的复制
题目描述
现在要把m本有顺序的书分给k给人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如不能把第一、第三、第四本书给同一个人抄写。
现在请你设计一种方案,使得复制时间最短。复制时间为抄写页数最多的人用去的时间。
输入输出格式
输入格式:
第一行两个整数m,k;(k≤m≤500)
第二行m个整数,第i个整数表示第i本书的页数。
输出格式:
共k行,每行两个整数,第i行表示第i个人抄写的书的起始编号和终止编号。k行的起始编号应该从小到大排列,如果有多解,则尽可能让前面的人少抄写。
输入输出样例
9 3
1 2 3 4 5 6 7 8 9
1 5
6 7
8 9
分析:两种做法。
一dp做法:
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<math.h>
using namespace std;
int k,m,s;
int a[],d[];
int f[][];
int ans[][];
int main()
{
scanf("%d%d",&m,&k);memset(f,0x7f,sizeof(f));
for(int i=;i<=m;i++)
{
scanf("%d",&a[i]);
d[i]=d[i-]+a[i];
f[][i]=d[i];
}
for(int i=;i<=k;i++)//k个人,枚举分给的人数。
for(int j=;j<=m;j++)//枚举i个人共分给j本书
for(int l=;l<j;l++)
if((s=max(f[i-][l],d[j]-d[l]))<f[i][j])
f[i][j]=s;
//这个方案有限制条件
if(k==) printf("");else
if(k==) printf("1 %d\n",m);
else
{
int i=,j=m,kk=k;
for( i=m;i>=;i--)
{
if(d[j]-d[i-]>f[k][m])
{
ans[kk][]=i+,ans[kk--][]=j;
j=i;
}
}
printf("1 %d\n",j);
for(int i=;i<=k;i++)
printf("%d %d\n",ans[i][],ans[i][]);
} return ;
} //时间复杂度O(k*m)
第二种二分答案:
本题要求“最优分配方案,使分配给每一个抄写员的页数的最大值最小。” 也就是分配尽量平均,这样,最大值才能尽量小。
但是如果每本书的页数相差太大
int check(int x)
{
int sum=,tot=;//用了sum个人,最后一个人抄了tot页
for(int i=;i<=m;i++)
{
if((tot+a[i])<=x)
tot+=a[i];
else
tot=a[i],sum++; //这个代码的话,就默认了下一个人肯定能抄这本书。也就是说默认了a[i]<=x,所以需要把可行最小值l=max(页数a[i]).
}
return sum;
}
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<math.h>
using namespace std;
int m,n,all;
int a[];
int ans[][];
int check(int x)
{
int sum=,tot=;//用了sum个人,最后一个人抄了tot页
for(int i=;i<=m;i++)
{
if((tot+a[i])<=x)
tot+=a[i];
else
tot=,sum++,i--;
if(sum>m) return sum;
}
return sum;
}
int main()
{
scanf("%d%d",&m,&n);
if(n==) {printf("");return ;}
if(n==) {printf("1 %d",m);return ;}
int l=,mid;
for(int i=;i<=m;i++)
scanf("%d",&a[i]),all+=a[i];//l=max(l,a[i])
int r=all;
while(l<=r)
{
mid=(l+r)>>;
if(check(mid)>n)
l=mid+;
else r=mid-;
}
cout<<l;
int i=m,tot=,last=m,t=n;
for(i;i>=;i--)
{
if((tot+a[i])>l)
{
ans[t][]=i+,ans[t][]=last;t--;
last=i;tot=a[i];
}else
tot+=a[i];
}
/*
printf("1 %d\n",last);
for( i=2;i<=n;i++)
printf("%d %d\n",ans[i][0],ans[i][1]);
*/
return ;
}
P1281 书的复制的更多相关文章
- 洛谷 P1281 书的复制 题解
P1281 书的复制 题目背景 大多数人的错误原因:尽可能让前面的人少抄写,如果前几个人可以不写则不写,对应的人输出0 0. 不过,已经修改数据,保证每个人都有活可干. 题目描述 现在要把m本有顺序的 ...
- 洛谷 P1281 书的复制
书的复制 Code: #include <iostream> #include <cstdio> #include <cstring> using namespac ...
- 洛谷P1281 书的复制
题目描述 现在要把m本有顺序的书分给k给人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如不能把第一.第三.第四本书给同一个人抄写. ...
- P1281 书的复制[二分]
题目描述 现在要把m本有顺序的书分给k给人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如不能把第一.第三.第四本书给同一个人抄写. ...
- 【洛谷P1281 书的复制】二分+动态规划
分析 两个做法,一个DP,一个是二分. 二分:也就是二分枚举每个人分到的东西. DP:区间DP F[I][J]表示前i本书分给j个人用的最短时间 由于每一次j的状态由比j小的状态得出,所以要先枚举j, ...
- luoguP1281 书的复制 DP,贪心
luoguP1281 书的复制 链接 https://www.luogu.org/problemnew/show/P1281 思路 简单dp,输出方案. 很明显dp记录路径对不对? 恭喜你死了. 求出 ...
- 题解 洛谷P1281 【书的复制】
蒟蒻的\(DP\)很菜,\(SO\)我准备上一套二分的玄学操作 一.简单的二分答案 二分主要是用来解决一些最值问题,它可以有效的优化暴力,使复杂度减少到\(O(logn)\). 我先给大家介绍一下二分 ...
- 「LuoguP1281」 书的复制(贪心
Description 大多数人的错误原因:尽可能让前面的人少抄写,如果前几个人可以不写则不写,对应的人输出0 0. 不过,已经修改数据,保证每个人都有活可干. // 现在要把m本有顺序的书分给k给人 ...
- 【DP】书的复制
原题链接__戳我噢 [思路] (区间)DP F[I][J]表示前i本书分给j个人用的最短时间 由于每一次j的状态由比j小的状态得出,所以要先枚举j,然后枚举i,接着枚举上一次抄书的人是谁 我觉得,难点 ...
随机推荐
- CyclicBarrier及CountDownLatch的使用
CountDownLatch位于java.util.concurrent包下,是JDK1.5的并发包下的新特性. 首先根据Oracle的官方文档看看CountDownLatch的定义: A synch ...
- jquery跨域3
这两天用 Jquery 跨域取数据的时候,经常碰到 invalid label 这个错误,十分的郁闷,老是取不到服务器端发送回来的 json 值, 一般跨域用到的两个方法为:$.ajax 和$.get ...
- 「NOI1999」「LuoguP1731」生日蛋糕(爆搜剪枝
题目背景 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层 生日蛋糕,每层都是一个圆柱体. 设从下往上数第i(1<=i<=M)层蛋糕是半径为Ri, 高度为Hi的圆柱 ...
- 「UOJ#117」 欧拉回路
欧拉回路 - 题目 - Universal Online Judge 题意: 给定有向图或无向图,求一条欧拉回路. 题解 心路历程:woc什么傻哔东西->哇真香我的吗!(逃 首先我知道很多人把欧 ...
- [Balkan 2007] Mokia
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1176 [算法] CDQ分治 + 树状数组即可 时间复杂度 : O(Nlog^2N) ...
- 洛谷P4013数字梯形问题——网络流24题
题目:https://www.luogu.org/problemnew/show/P4013 最大费用最大流裸题: 注意:在第二种情况中,底层所有点连向汇点的边容量应该为inf,因为可以有多条路径结束 ...
- c++函数模板1
1 定义: 函数模板 只适用于参数个数相同但是类型不同 而且函数体相同的情况 2 这个例子没有使用模板的情况 #include <iostream> using namespace std ...
- Flex AIR组件
1.FileSystemComboBox .directory = File.appli / desk/doc / directoryChange 2.FileSystemTree可返回 好用 ...
- supervisor简明教程
一.supervisor是什么 Linux的后台进程运行有好几种方法,例如nohup,screen等,但是,如果是一个服务程序,要可靠地在后台运行,我们就需要把它做成daemon,最好还能监控进程状态 ...
- supervisor uwsgi配置文件
; ================================ ; uwsgi supervisor ; ================================ [program:uw ...