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,接着枚举上一次抄书的人是谁 我觉得,难点 ...
随机推荐
- vertical-align 的理解
1.vertical-align 属性和值列表
- C++之引用&的详解
C++中的引用: 引用引入了对象的一个同义词.定义引用的表示方法与定义指针相似,只是用&代替了*.引用(reference)是c++对c语言的重要扩充.引用就是某一变量(目标)的一个别名,对引 ...
- bzoj 3309 DZY Loves Math——反演+线性筛
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3309 像这种数据范围,一般是线性预处理,每个询问 sqrt (数论分块)做. 先反演一番.然 ...
- bzoj1013高斯消元
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1013 似乎是很明显的高斯消元: 第一次写高斯消元. 代码如下: #include<io ...
- CSS:CSS 颜色十六进制值
ylbtech-CSS:CSS 颜色十六进制值 1.返回顶部 1. 根据十六进制值排序 所有浏览器都支持的颜色名 根据颜色名排序的相同列表 颜色名 十六进制颜色值 颜色 Black #000000 ...
- Android开发--Activity
一:Activity生命周期 (1)Activity生命周期中的几种方法: protected void onCreate(Bundle savedInstanceState): protected ...
- 4.1-4.2 基于HDFS云盘存储系统分析及hadoop发行版本
一.基于HDFS云盘存储系统 如:某度网盘 优点: *普通的商用机器 内存 磁盘 *数据的安全性 操作: *put get *rm mv *java api *filesystem 核心: *H ...
- Ubuntu安装vnc+gnome的xstartup配置
Log 1 安装vncserver并且在xstartup配置gnome 背景:学习Ruby,想在ubuntu下使用rubymine 时间:2014-3-10 环境:Ubuntu 记录:Roy 其实这个 ...
- Laravel中的查询构造器
public function query(){ //新增数据 //$bool = DB::table('wd_user')->insert(['username'=>'jack']); ...
- E20190303-hm
invoke vt. 乞灵,祈求; 提出或授引…以支持或证明; 召鬼; 借助;