题目描述

现在要把m本有顺序的书分给k给人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如不能把第一、第三、第四本书给同一个人抄写。

现在请你设计一种方案,使得复制时间最短。复制时间为抄写页数最多的人用去的时间。

输入输出格式

输入格式:

第一行两个整数m,k;(k≤m≤500)

第二行m个整数,第i个整数表示第i本书的页数。

输出格式:

共k行,每行两个整数,第i行表示第i个人抄写的书的起始编号和终止编号。k行的起始编号应该从小到大排列,如果有多解,则尽可能让前面的人少抄写。

输入输出样例

输入样例#1:

9 3
1 2 3 4 5 6 7 8 9
输出样例#1:

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 书的复制的更多相关文章

  1. 洛谷 P1281 书的复制 题解

    P1281 书的复制 题目背景 大多数人的错误原因:尽可能让前面的人少抄写,如果前几个人可以不写则不写,对应的人输出0 0. 不过,已经修改数据,保证每个人都有活可干. 题目描述 现在要把m本有顺序的 ...

  2. 洛谷 P1281 书的复制

    书的复制 Code: #include <iostream> #include <cstdio> #include <cstring> using namespac ...

  3. 洛谷P1281 书的复制

    题目描述 现在要把m本有顺序的书分给k给人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如不能把第一.第三.第四本书给同一个人抄写. ...

  4. P1281 书的复制[二分]

    题目描述 现在要把m本有顺序的书分给k给人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如不能把第一.第三.第四本书给同一个人抄写. ...

  5. 【洛谷P1281 书的复制】二分+动态规划

    分析 两个做法,一个DP,一个是二分. 二分:也就是二分枚举每个人分到的东西. DP:区间DP F[I][J]表示前i本书分给j个人用的最短时间 由于每一次j的状态由比j小的状态得出,所以要先枚举j, ...

  6. luoguP1281 书的复制 DP,贪心

    luoguP1281 书的复制 链接 https://www.luogu.org/problemnew/show/P1281 思路 简单dp,输出方案. 很明显dp记录路径对不对? 恭喜你死了. 求出 ...

  7. 题解 洛谷P1281 【书的复制】

    蒟蒻的\(DP\)很菜,\(SO\)我准备上一套二分的玄学操作 一.简单的二分答案 二分主要是用来解决一些最值问题,它可以有效的优化暴力,使复杂度减少到\(O(logn)\). 我先给大家介绍一下二分 ...

  8. 「LuoguP1281」 书的复制(贪心

    Description 大多数人的错误原因:尽可能让前面的人少抄写,如果前几个人可以不写则不写,对应的人输出0 0. 不过,已经修改数据,保证每个人都有活可干. // 现在要把m本有顺序的书分给k给人 ...

  9. 【DP】书的复制

    原题链接__戳我噢 [思路] (区间)DP F[I][J]表示前i本书分给j个人用的最短时间 由于每一次j的状态由比j小的状态得出,所以要先枚举j,然后枚举i,接着枚举上一次抄书的人是谁 我觉得,难点 ...

随机推荐

  1. Swift类型转换

    关于「类型转换」(Type Casting),<The Swift Programming Language>描述如下: Type casting is a way to check th ...

  2. centos7升级最新内核

    由于最近在测试ceph 的straw2算法,但是要使用straw2需要最新为4.1.0的内核,因此决定将虚机内核升级最新4.11.4. 步骤1.检查本机内核版本 #uname -sr 3.10.0-5 ...

  3. Laravel中的查询构造器

    public function query(){ //新增数据 //$bool = DB::table('wd_user')->insert(['username'=>'jack']); ...

  4. POJ - 2251 Dungeon Master 多维多方向BFS

    Dungeon Master You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is ...

  5. 将字符串中的字符按Z字形排列,按行输出

    示例1: Input: s = "PAYPALISHIRING", numRows = 3 Output: "PAHNAPLSIIGYIR" 示例2: Pyth ...

  6. ZOJ3163【思维题】

    每天取最远的那面 int main() { init(); int n,x,y; while(~scanf("%d%d%d",&n,&x,&y)) prin ...

  7. editplus 3.4注册码,亲测有效

    注册码: crsky 7879E-5BF58-7DR23-DAOB2-7DR30

  8. linux 搭建unixODBC ,并对接 PostgreSQL 9.3.4

    环境:suse 11 ,64位的操作系统 unixODBC 版本:2.3.2 PostgreSQL 9.3.4 1 编译安装 unixODBC 下载 unixODBC :http://www.unix ...

  9. 【IDEA】关于 IDEA 中新建 web 项目的 webapp 文件夹没有小蓝点 ,启动服务,访问不到解决方案

    问题描述: 新建的 maven 的 Module 项目,webapp 文件夹也是在创建完项目后手动添加的,出现了 webapp 文件夹不能被识别的情况. 解决方案: 第一步:  选中项目按 F4 键, ...

  10. bzoj1142:[POI2009]Tab

    传送门 考虑每次交换都不会改变每个数所在的行和列(不是指编号,而是指和它在同一行或者同一列的数不会发生变化) 由于每个数互不相同,所以记录下每个数所在的行和列,暴力判断就好了 代码: #include ...