首页 > 其他分享 >WQS 二分

WQS 二分

时间:2024-04-12 19:12:54浏览次数:28  
标签:二分 WQS 白边 凸函数 物品 切点 need 最优

一个参考

WQS 二分用来处理一些答案构成凸函数的问题。

最经典、最常见的形式,就是 "从若干个物品中恰好选给定个数的最优" 型问题。

适用要求:如果不考虑选的物品的个数限制,可以很快求出答案。

例题:P2619 Tree I

从所有白边中选 \(need\) 条,然后加上若干条黑边形成生成树,最优是多少。

为什么这是一个凸函数?记选 \(x\) 条白边的最优为 \(f(x)\),则 \(f(x)\) 会逐步趋向于最大值,再逐渐减小。

有没有可能最优是在 \(w\) 条白边时取到,但 \(i_1<i_2<w\) 时,反而 \(f(i_1)>f(i_2)\)?

考虑最优解,是由若干条白边连接若干个只有黑边的连通块。这是最优解说明任意两个用白边相连的连通块之间不存在边权更小的黑边。也就是只要换成黑边,代价不会下降。

\(i_1\) 的最优方案,可以看作是从 \(w\) 的最优解里面选取 \(w-i_1\) 条白边改成黑边。有没有可能是把 \(w\) 的某条黑边改成白边,某条白边改成黑边,反而比只把白边改成黑边严格更优?不可能,否则在 \(w\) 的最优解里面应用这个替换,与最优解矛盾。

所以 \(i_1\) 是选 \(w-i_1\) 条白边改成黑边,\(i_2\) 是选 \(w-i_2\) 条白边改成黑边。上面说了任何白边改成黑边,代价都单调不降。因为 \(w-i_1>w-i_2\),所以 \(i_1\) 改后会更加单调不降。因此不可能。

同理可以证明 \(w<i_1<i_2\) 时,\(f(i_1)>f(i_2)\)。因此得到 \(f\) 是一个凸函数。(而且是上凸函数,因为选一条边后总代价不可能减少)

证明是凸函数,然后怎么做?

上凸函数有一个性质:考虑一条斜率为 \(k\) 的直线与 \(f\) 的切点横坐标 \(X\),满足 \(f\) 随着 \(k\) 的减小而增大。(在图上画一下就能看出来)

如果我们能求出切点横坐标 \(X\),将其与 \(need\) 比较,就可以得到我们二分的 \(k\) 是多少。我们的目标是找到一个 \(k\) 使它与 \(f\) 的切点横坐标为 \(need\)(为什么后面会说)。

那么如何求出切点横坐标 \(X\)?已知信息只有一个 \(k\)。而且注意我们必须快速求出 \(X\),如果是平方级别的,算法根本没有优化反而还慢了。

性质:令 \(g(x)=f(x)-k\times x\),则 \(g(X)\) 为 \(g\) 的最大值。

很好理解,因为 \(g\) 相当于求一条斜率为 \(k\) 的直线过一个点的截距。而上凸函数切点处的截距一定是最大的。

结论:\(g(X)\) 为所有物品价值减去 \(k\) 后,不限制物品个数的最大价值。

为什么?发现此时的 \(f(i)\) 会变成 \(f(i)-k\times i\),而不限制物品个数就是求 \(\max(f(i)-k\times i)=\max(g(i))\),根据上面的性质 \(g(X)\) 就是最大值。

因为我们可以快速求出不限制物品个数的最大值,所以自然也可以快速求出 \(g(X)\)。在求 \(g(X)\) 的时候顺便统计一下,可以得到 \(X\)(上面的理论保证了在最优情况下的统计结果一定是 \(X\))。

怎么求 \(X\) 结束了。于是我们可以通过二分找到一个斜率 \(K\),使每个物品价值减去 \(K\) 后不限制个数的最优解恰好是选择 \(need\) 个物品。

使每个物品价值减去 \(K\),然后跑一次不限制物品个数的算法得到答案为 \(ans\),最终答案为 \(ans+K\times need\)。(这里要特别注意记得把减去的加回来

这道题还预留有一个问题:有可能我们根本二分不到 \(need\)!

这是一个例子,当切点有很多个且 \(need\) 在中间,怎么找到 \(need\) ?

答案是我们不需要找到 \(need\),因为都被同一个斜率切的顶点,对应的截距都是相同的。只要找到的截距是被这个斜率切的,加上 \(k\times need\) 后一定会得到 \(need\) 的最优。

标签:二分,WQS,白边,凸函数,物品,切点,need,最优
From: https://www.cnblogs.com/FLY-lai/p/18129706

相关文章

  • [离线技巧] 整体二分
    来介绍一下整体二分。整体二分需要满足一下条件:问题之间独立可以离线具有单调性答案贡献可合并我们通过几个例子,通俗的理解这个算法。问题\(1\)给定\(n\)个数,求第\(k\)小。我们思考这个问题怎么做。不用排序,显然,答案具有单调性。那么,我们可以二分一个答案,判断......
  • lc162 寻找峰值(二分法)
      二分法找部分有序数组题class Solution {    public int findPeakElement(int[] nums) {     int left=0;     int right=nums.length-1;     while(left<right){//因为这道题需要用mid和mid+1比较,所以左右不可以相等否则mid+1会越界  ......
  • 二分查找与二分答案(1.)
    1.二分查找大家还知道怎么在一本很厚的词典查找一个单词吗?字典中的单词是按照“字典序”进行排序的,比如code<pan<pancake。如果我们要找一个单词,就要将字典从中间翻开,然后将这面单词跟想要找的单词比较。如果这面单词在需要寻找的单词之前,就将字典往后翻,否则就往前翻,直到找......
  • C++U4新-第06课-二分答案
    二分答案学习目标 先学习单调性,二分查找的单调性意思二分答案单调性 二分答案的思路  [【二分答案】-砍树] #include<iostream>usingnamespacestd;intmain(){intn,m;inttree[1000005];cin>>n>>m;for(inti=1;i<=n;i......
  • 蓝桥杯-【二分】求阶乘
     思路:对于有几个0,10一定会是5的整数倍,2的因子数一定比5的多,所以只要算5的个数即可, 30%,每个n都去算#include<bits/stdc++.h>usingnamespacestd;#definelllonglongllcheck(lln){//计算n!末尾有多少个0llcnt=0;while(n)cnt+=......
  • P2440:木材加工——P2678:跳石头 【二分答案】
    P2440木材加工【二分答案】题目背景要保护环境题目描述木材厂有n根原木,现在想把这些木头切割成k段长度均为l的小段木头(木头有可能有剩余)。当然,我们希望得到的小段木头越长越好,请求出l的最大值。木头长度的单位是cm,原木的长度都是正整数,我们要求切割得到的小段木......
  • 二分——二分查找,二分答案
    二分查找二分查找也称折半查找,它是一种效率极高的查找方法。但是折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列,就是:数据要是有序排列的。备注:二分查找的一个非常重要的前提条件就是查找的内容具备单调性举个例子假如我们需要在10亿个不同的数字当中找......
  • 三种算法实例(二分查找算法、插入排序算法、贪心算法)
    当我们听到“算法”这个词时,很自然地会想到数学。然而实际上,许多算法并不涉及复杂数学,而是更多地依赖基本逻辑,这些逻辑在我们的日常生活中处处可见。在正式探讨算法之前,有一个有趣的事实值得分享:你已经在不知不觉中学会了许多算法,并习惯将它们应用到日常生活中了。下面我将举......
  • 保龄球(二分)
    题目描述DL算缘分算得很烦闷,所以常常到体育馆去打保龄球解闷。因为他保龄球已经打了几十年了,所以技术上不成问题,于是他就想玩点新花招。DL的视力真的很不错,竟然能够数清楚在他前方十米左右每个位置的瓶子的数量。他突然发现这是一个炫耀自己好视力的借口——他看清远方瓶......
  • 最长上升子序列——二分法
    前置设lowilow_ilowi​:长度为......