题目描述

现在要把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. 使用geolocation

    The geolocation object geolocation API建立在navigator.geolocation 上. 如果对象存在,才可以使用定位服务. if ("geoloc ...

  2. hdu-5768 Lucky7(容斥定理+中国剩余定理)

    题目链接: Lucky7 Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 65536/65536 K (Java/Others) Pr ...

  3. hdu-5621 KK's Point(dp+数学)

    题目链接: KK's Point Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 65536/65536 K (Java/Others ...

  4. kamailio/opensips snmp/cacti/zabbix监控

        kamailio/opensips是现在比较流行的sip proxy,有配置灵活.性能强大.支持各种RFC等优点,是杀人越货.谈情说爱是必备佳品.要保证这么好的东西稳定运行,监控是必不可少的, ...

  5. linux内存占用分析

    概述 想必在linux上写过程序的同学都有分析进程占用多少内存的经历,或者被问到这样的问题——你的程序在运行时占用了多少内存(物理内存)?通常我们可以通过top命令查看进程占用了多少内存.这里我们可以 ...

  6. 配置tomcat https的步骤

    keytool -genkey -v -alias tomcat -keyalg RSA -keystore D:\tomcat.keystore -validity 36500 keytool -g ...

  7. Ubuntu18.04 安装 JDK7

    直接下载jdk压缩包方式安装 1.官网下载JDK      地址: http://www.oracle.com/technetwork/articles/javase/index-jsp-138363 ...

  8. Union All ,Merge,Merge join 区别

    本文转自:http://www.cnblogs.com/gudujianxiao/archive/2012/07/17/2594709.html SSIS Data Flow 中有几个组件可以实现不同 ...

  9. C++11: Multi-core Programming – PPL Parallel Aggregation Explained

    https://katyscode.wordpress.com/2013/08/17/c11-multi-core-programming-ppl-parallel-aggregation-expla ...

  10. 技术胖Flutter第三季-16Stack层叠布局

    16Stack层叠布局 在上面声明一个变量Stack里面包含两个元素,第一个 是CircleAvater第二个子对象是Container 效果 把文字房子啊中下的位置: 我们需要对齐属性 包含了x轴和 ...