by zkw, Jul 17, 2016, 4:13 PM
First, here is a trivial DP solution with
. Let
data:image/s3,"s3://crabby-images/8830d/8830d6d3e0ec078dfe6d4513882946273416bd47" alt="$f(a,b)$"
be the minimum worst-case cost to guess a number
, then we have
data:image/s3,"s3://crabby-images/bc874/bc8748209af96ae4a881411e0556b2e3fe452387" alt="$$
f(a,b)=\min_{a\le k\le b}\Big(\max\big\{ f(a,k-1),f(k+1,b)\big\}+k\Big)\ .
$$"
Enumerate
data:image/s3,"s3://crabby-images/5dc86/5dc86eff05ae32df34e9998e09eda5d26be648be" alt="$k$"
and we are done. To optimize the computation, let
data:image/s3,"s3://crabby-images/efa89/efa8931ab7d79e5eb5dbc71f7ef75510775b1241" alt="$$
k_{0}(a,b)=\max\{k:f(a,k-1)\le f(k+1,b)\}\ ,
$$"
then
data:image/s3,"s3://crabby-images/6aa60/6aa60f8577d65d234af66316efe392b27fb48ea8" alt="\begin{align*}
& \max\big\{ f(a,k-1),f(k+1,b)\big\}\\
= & \begin{cases}
f(k+1,b) & \text{if }a\le k\le k_{0}(a,b)\\
f(a,k-1) & \text{if }k_{0}(a,b)<k\le b
\end{cases}\;.
\end{align*}"
Therefore,
data:image/s3,"s3://crabby-images/1d202/1d20266f297199b22f030d6dbc21af3eb995f921" alt="\begin{align*}
f(a,b) & =\min\big\{ f_{1}(a,b),f_{2}(a,b)\big\}\\
f_{1}(a,b) & =\min_{a\le k\le k_{0}(a,b)}\big(f(k+1,b)+k\big)\\
f_{2}(a,b) & =\min_{k_{0}(a,b)<k\le b}\big(f(a,k-1)+k\big)\\
& =f\big(a,k_{0}(a,b)\big)+k_{0}(a,b)+1\ .
\end{align*}"
Notice that
data:image/s3,"s3://crabby-images/00f94/00f94956657eac3e6cc4ae9815ae5bc10ca1238f" alt="$k_{0}(a_{1},b)\le k_{0}(a_{2},b)$"
when
. So we can compute
data:image/s3,"s3://crabby-images/5d4e7/5d4e72a64f61014e28d2401bcfa689ceedbebbbb" alt="$k_{0}(a,b)$"
in amortized
data:image/s3,"s3://crabby-images/f218f/f218f0f7be91ed8120c82e67ef9ba1e82a073dc9" alt="$O(1)$"
time. Then we need the sliding minimum of
data:image/s3,"s3://crabby-images/d8206/d820645d7de992948ff5290d81e79e70b7865d3c" alt="$g(k,b)=f(k+1,b)+k$"
with
data:image/s3,"s3://crabby-images/59dd5/59dd52d5097b2de3b08211f8e78f04929beaa818" alt="$b$"
fixed and
. This can be done using an increasing deque, and it takes amortized
data:image/s3,"s3://crabby-images/f218f/f218f0f7be91ed8120c82e67ef9ba1e82a073dc9" alt="$O(1)$"
time to get the desired minimum. We need to compute
data:image/s3,"s3://crabby-images/44cdb/44cdb5377be0a3a2b3c8d1f4c5402c0b787a77f7" alt="$O(n^{2})$"
values of
, and each takes
data:image/s3,"s3://crabby-images/f218f/f218f0f7be91ed8120c82e67ef9ba1e82a073dc9" alt="$O(1)$"
time, so in all
.
Program (in C++)
This post has been edited 10 times. Last edited by zkw, Jul 21, 2016, 9:46 AM