Distribution of Books
zz6d likes reading very much, so he bought a lot of books. One day, zz6d brought n books to a classroom in school. The books of zz6d is so popular that K students in the classroom want to borrow his books to read. Every book of zz6d has a number i (1<=i<=n). Every student in the classroom wants to get a continuous number books. Every book has a pleasure value, which can be 0 or even negative (causing discomfort). Now zz6d needs to distribute these books to K students. The pleasure value of each student is defined as the sum of the pleasure values of all the books he obtains.Zz6d didn’t want his classmates to be too happy, so he wanted to minimize the maximum pleasure of the K classmates. zz6d can hide some last numbered books and not distribute them,which means he can just split the first x books into k parts and ignore the rest books, every part is consecutive and no two parts intersect with each other.However,every classmate must get at least one book.Now he wonders how small can the maximum pleasure of the K classmates be.
1<=T<=10
1<=n<=2*105
1<=k<=n
-109<=ai<=109
分析
最大值最小,考虑二分答案。思考题目是否具有单调性:当最大值极大时,书可以随便分,当最大值极小时,可能会出现无法凑齐的状况,目测满足。
题目要求分书时必须连续分,可以使用动态规划来做。假设二分的答案为lim
将求和改为前缀和,。
动态规划的复杂度为,太慢,考虑优化。
每次转移都从先前已经出现的满足要求的f中转移。限制条件转一下,就是
- 当有2个f对应的前缀和相同,我们选择更大的那个
所以可以直接维护已经出现的每种前缀和所对应的最大f。可以离散化后使用权值线段树。复杂度变为
总复杂度为。
代码
1 |
|
多组询问没有清理干净数组,WA了好几发。