第一道决策单调性……

题目描述

HHHOJ#261. Brew


题目分析

挺好的……模板题?

寄存了先。

 #include<bits/stdc++.h>
typedef long long ll;
const int maxn = ; struct node
{
int x,l,r;
node(int a=, int b=, int c=):x(a),l(b),r(c) {}
};
int n,k,a[maxn],g[maxn];
ll s[maxn],mid,pos,ans,f[maxn];
std::deque<node> q; int read()
{
char ch = getchar();
int num = ;
bool fl = ;
for (; !isdigit(ch); ch=getchar())
if (ch=='-') fl = ;
for (; isdigit(ch); ch=getchar())
num = (num<<)+(num<<)+ch-;
if (fl) num = -num;
return num;
}
void clears(std::deque<node> &q)
{
std::deque<node> emt;
std::swap(q, emt);
}
ll val(int l, int r)
{
if (l >= r) return ;
int mid = (l+r)>>;
return 1ll*(mid-l+)*a[mid]-(s[mid]-s[l-])+(s[r]-s[mid-])-1ll*(r-mid+)*a[mid];
}
ll calc(int l, int r)
{
return f[l]+val(l+, r);
}
bool check(ll w)
{
clears(q), q.push_front(node(, , n));
for (int i=; i<=n; i++)
{
// printf("w:%lld i:%d\n",w,i);
node tt = q.front();
g[i] = g[tt.x]+, f[i] = calc(tt.x, i)+w;
int upd = -;
while (q.size())
{
node tt = q.back();
if (calc(tt.x, tt.l) > calc(i, tt.l))
upd = tt.l, q.pop_back();
else{
int lbd = tt.l, rbd = tt.r, fnd = -;
while (lbd <= rbd)
{
int mid = (lbd+rbd)>>;
if (calc(tt.x, mid) > calc(i, mid))
fnd = mid, rbd = mid-;
else lbd = mid+;
}
if (fnd!=-) upd = fnd, q.back().r = fnd-;
break;
}
}
if (upd!=-) q.push_back(node(i, upd, n));
if (q.size()){
q.front().l++;
if (q.front().l > q.front().r) q.pop_front();
}
}
return g[n] <= k;
}
int main()
{
n = read(), k = read();
if (k >= n) puts("");
else{
for (int i=; i<=n; i++) a[i] = read();
std::sort(a+, a+n+);
for (int i=; i<=n; i++) s[i] = s[i-]+a[i];
ll l = , r = 1e12;
for (; l<=r; )
{
mid = (l+r)>>;
if (check(mid))
ans = f[n]-mid*k, r = mid-;
else l = mid+;
}
printf("%lld\n",ans);
}
return ;
}

END

【wqs二分 决策单调性】HHHOJ#261. Brew的更多相关文章

  1. 【wqs二分 || 决策单调性】cf321E. Ciel and Gondolas

    把状态看成层,每层决策单调性处理 题目描述 题目大意 众所周知,贞鱼是一种高智商水生动物.不过他们到了陆地上智商会减半.这不?他们遇到了大麻烦!n只贞鱼到陆地上乘车,现在有k辆汽车可以租用.由于贞鱼们 ...

  2. BZOJ5311 贞鱼(动态规划+wqs二分+决策单调性)

    大胆猜想答案随k变化是凸函数,且有决策单调性即可.去粘了份fread快读板子才过. #include<iostream> #include<cstdio> #include&l ...

  3. P3515-[POI2011]Lightning Conductor【整体二分,决策单调性】

    正题 题目链接:https://www.luogu.com.cn/problem/P3507 题目大意 \(n\)个数字的一个序列\(a\),对于每个位置\(i\)求一个\(p_i\)使得对于任意\( ...

  4. CF321E Ciel and Gondolas Wqs二分 四边形不等式优化dp 决策单调性

    LINK:CF321E Ciel and Gondolas 很少遇到这么有意思的题目了.虽然很套路.. 容易想到dp \(f_{i,j}\)表示前i段分了j段的最小值 转移需要维护一个\(cost(i ...

  5. 决策单调性&wqs二分

    其实是一个还算 trivial 的知识点吧--早在 2019 年我就接触过了,然鹅当时由于没认真学并没有把自己学懂,故今复学之( 1. 决策单调性 引入:在求解 DP 问题的过程中我们常常遇到这样的问 ...

  6. DP的各种优化(动态规划,决策单调性,斜率优化,带权二分,单调栈,单调队列)

    前缀和优化 当DP过程中需要反复从一个求和式转移的话,可以先把它预处理一下.运算一般都要满足可减性. 比较naive就不展开了. 题目 [Todo]洛谷P2513 [HAOI2009]逆序对数列 [D ...

  7. Gym - 101981B Tournament (WQS二分+单调性优化dp)

    题意:x轴上有n个人,让你放置m个集合点,使得每个人往离他最近的集合点走,所有人走的距离和最短. 把距离视为花费,设$dp[i][k]$表示前i个人分成k段的最小花费,则有递推式$dp[i][k]=m ...

  8. bzoj 2216 [Poi2011]Lightning Conductor——单调队列+二分处理决策单调性

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2216 那个关于位置的代价是带根号的,所以随着距离的增加而增长变慢:所以靠后的位置一旦比靠前的 ...

  9. bzoj 4709 [Jsoi2011]柠檬——单调栈二分处理决策单调性

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4709 题解:https://blog.csdn.net/neither_nor/articl ...

随机推荐

  1. Kali Linux 工具清单

    Kali Linux 工具清单 Information Gathering acccheck ace-voip Amap Automater bing-ip2hosts braa CaseFile C ...

  2. 黑马旅游网 ajax+html在前端实现页标签个数控制

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. SonarQube总结

    官网:https://www.sonarqube.org/ 一款代码质量管理开源平台.

  4. MySQL无法启动Couldn't find MySQL server (/usr/bin/mysqld_safe)解决办法(来源网络)

    MySQL无法启动Couldn't find MySQL server (/usr/bin/mysqld_safe) 启动的时候,报上述错误,从这个报错来看,多半是因为读取到了另外的my.cnf导致的 ...

  5. bzoj 5337 [TJOI2018] str

    bzoj 5337 [TJOI2018] str Link Solution 水题 直接 \(f[i][j]\) 表示以第 \(i\) 位为结束位置,当前已经匹配了前 \(j\) 个氨基酸的方案数 使 ...

  6. CodeForces - 508B-Anton and currency you all know

    Berland, 2016. The exchange rate of currency you all know against the burle has increased so much th ...

  7. java中 json和bean list map之间的互相转换总结

    JSON 与 对象 .集合 之间的转换 JSON字符串和java对象的互转[json-lib]   在开发过程中,经常需要和别的系统交换数据,数据交换的格式有XML.JSON等,JSON作为一个轻量级 ...

  8. LinkedList源码及原理

    简介 内部结构分析 LinkedList源码分析 构造方法 添加(add)方法 根据位置取数据的方法 根据对象得到索引的方法 检查链表是否包含某对象的方法: 删除(remove/pop)方法 Link ...

  9. (转)Linux命令之Ethtool用法详解

    Linux命令之Ethtool用法详解 原文:http://www.linuxidc.com/Linux/2012-01/52669.htm Linux/Unix命令之Ethtool描述:Ethtoo ...

  10. 日志AOP的实现

    /// <summary> /// 日志AOP拦截 /// </summary> [AttributeUsage(AttributeTargets.Method, AllowM ...