bzoj1044
好题
第一问不难,毕竟二分答案类的题目在USACO上都练了好多遍了
第二问充分的暴露了我dp渣的本性
一开始楞是没想出来
f[i,j]表示到第i根木棒切了j刀满足最长段小于等于ans的方案数
式子是这样的f[i,j]=sigma(f[k,j-1]) if sum[i]-sum[k]<=ans
然后发现我的优化水平还是不错的,
首先是空间上的问题,观察得知,切这刀的方案数只与切前一刀有关,于是我们滚动数组
再看时间,观察k的选取,与这是第几刀无关
再看,如果满足sum[i]-sum[k]<=ans 那么k~i-1一定都是符合的切法
于是我们预先处理一下即可
复杂度为O(nlogn+mn)
const mo=;
var f:array[..,..] of longint;
sum,s,a,b:array[..] of longint;
p,l,r,mid,n,m,i,j,t,ans:longint; function check(s:longint):boolean;
var t,len,i:longint;
begin
t:=;
len:=;
p:=;
for i:= to n do
if len+a[i]>s then
begin
inc(t);
if t>m then exit(false);
if len>p then p:=len;
len:=a[i];
end
else len:=len+a[i];
if len>p then p:=len;
exit(true);
end;
begin
readln(n,m);
for i:= to n do
begin
readln(a[i]);
sum[i]:=sum[i-]+a[i];
if l<a[i] then l:=a[i];
end;
r:=sum[i];
while l<=r do //二分答案
begin
mid:=(l+r) shr ;
if check(mid) then
begin
ans:=p;
r:=p-;
end
else l:=mid+;
end;
for i:= to n do
if sum[i]<=ans then f[,i]:= else break;
j:=;
for i:= to n do //预处理
begin
while sum[i]-sum[j]>ans do inc(j);
b[i]:=j;
end;
p:=;
t:=f[p,n];
for i:= to m do
begin
p:=-p;
fillchar(s,sizeof(s),);
for j:= to n do
begin
if b[j]-> then r:=b[j]- else r:=; //小细节
f[p,j]:=(s[j-]-s[r]+mo) mod mo;
s[j]:=(s[j-]+f[-p,j]) mod mo;
end;
t:=(t+f[p,n]) mod mo;
end;
writeln(ans,' ',t);
end.
bzoj1044的更多相关文章
- 【czy系列赛】czy的后宫6 && bzoj1044 [HAOI2008]木棍分割
题目描述 众所周知的是丧尸czy有很多妹子(虽然很多但是质量不容乐观QAQ),今天czy把n个妹子排成一行来检阅.但是czy的妹子的质量实在--所以czy看不下去了.检阅了第i个妹子会增加czy a[ ...
- 【BZOJ1044】[HAOI2008]木棍分割(动态规划,贪心)
[BZOJ1044][HAOI2008]木棍分割(动态规划,贪心) 题面 BZOJ 洛谷 题解 第一问随便二分一下就好了,贪心\(check\)正确性显然. 第二问随便前缀和+单调队列优化一下\(dp ...
- 【BZOJ1044】[HAOI2008]木棍分割
[BZOJ1044][HAOI2008]木棍分割 题面 bzoj 洛谷 题解 第一问显然可以二分出来的. 第二问: 设\(dp[i][j]\)表示前\(i\)个,切了\(j\)组的方案数 发现每次转移 ...
- [bzoj1044][HAOI2008][木棍分割] (二分+贪心+dp+队列优化)
Description 有n根木棍, 第i根木棍的长度为Li,n根木棍依次连结了一起, 总共有n-1个连接处. 现在允许你最多砍断m个连接处, 砍完后n根木棍被分成了很多段,要求满足总长度最大的一段长 ...
- BZOJ1044: [HAOI2008]木棍分割
1044: [HAOI2008]木棍分割 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1580 Solved: 567[Submit][Statu ...
- bzoj1044[HAOI2008]木棍分割 单调队列优化dp
1044: [HAOI2008]木棍分割 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4314 Solved: 1664[Submit][Stat ...
- 【bzoj1044】木棍分割
Description 有n根木棍, 第i根木棍的长度为Li,n根木棍依次连结了一起, 总共有n-1个连接处. 现在允许你最多砍断m个连接处, 砍完后n根木棍被分成了很多段,要求满足总长度最大的一段长 ...
- [BZOJ1044][HAOI2008]木棍分割 二分 + 单调队列优化dp + 滚动数组优化dp
Description 有n根木棍, 第i根木棍的长度为Li,n根木棍依次连结了一起, 总共有n-1个连接处. 现在允许你最多砍断m个连接处, 砍完后n根木棍被分成了很多段,要求满足总长度最大的一段长 ...
- bzoj1044: [HAOI2008]木棍分割 二分+dp
有n根木棍, 第i根木棍的长度为Li,n根木棍依次连结了一起, 总共有n-1个连接处. 现在允许你最多砍断m个连接处, 砍完后n根木棍被分成了很多段,要求满足总长度最大的一段长度最小, 并且输出有多少 ...
随机推荐
- c语言指针用法
一.指针 int t 定义整型变量 int *p p为指向整型数据的指针变量 int a[n] 定义整型数组a,它有n个元素 int *p[n] 定义指针数组p,它由n个指向整形数据的指针元素组成 i ...
- Oracle SQL的硬解析、软解析、软软解析
Oracle中每条sql在执行前都要解析,解析分为硬解析.软解析.软软解析. Oracle会缓存DML语句,相同的DML语句会进行软解析.但不会缓存DDL语句,所以DDL每次都做硬解析.硬解析是一个很 ...
- HTML标签语义对照表
标签名 英文全拼 中文翻译 div division 分隔 span span 范围 ol ordered list 排序列表 ul unordered list 不排序列表 li list item ...
- OnDrawGizmos函数
如果你想绘制可被点选的gizmos,执行这个函数. 这允许你在场景中快速选择重要的物体. 注意: OnDrawGizmos使用相对鼠标坐标 using UnityEngine; using Syste ...
- Indri中的动态文档索引技术
Indri中的动态文档索引技术 戴维 译 摘要: Indri 动态文档索引的实现技术,支持在更新索引的同时处理用户在线查询请求. 文本搜索引擎曾被设计为针对固定的文档集合进行查询,对不少应用来说,这种 ...
- xcode 6.3 打包crash问题--参考
xcode升级6.3之后,有些项目会出现打包crash的问题,只要选择偏好设置,把source control全部禁用掉就可以了.
- bnu 4359 无爱编号(规律)
http://www.bnuoj.com/bnuoj/problem_show.php?pid=4359 [题意]:输入N,表示几位数,0-这个N位数,有多少个满足条件的号码,不满足的情况为出现4,1 ...
- 1191: [HNOI2006]超级英雄Hero - BZOJ
Description 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的多少获得不同数目的奖品或奖金.主持人问题准备了若干道题目,只有当选手正确回 ...
- CNKI翻译助手-连接数据库失败
IP并发数限制,老师说西工大的CNKI才20个并发指标,HPU自不必说.但是我略表怀疑,这只是翻译助手而已,就像百度翻译和百度数据库的区别,如何验证呢?去校外用该助手,如果能用,那么就不是IP并发限制 ...
- swift苹果的下一代语言
http://numbbbbb.github.io/the-swift-programming-language-in-chinese/chapter1/01_swift.html 有时间再看,bas ...