\subsection{Problem 2}

Assume for contradiction that a universal hardcore bit function $h:\{0,1\}^n \rightarrow \{0,1\}$ exists.
Let $f_n' : \{0,1\}^n \rightarrow \{0,1\}^{q(n)}$ be any one-way function. We define a new function $f_n: \{0, 1\}^n \rightarrow \{0, 1\}^{q(n) + 1}$ by
$$
f_n(x) = f_n'(x) \| h(x),
$$
that is, we append the output of $h(x)$ to $f_n'(x)$. Observe that $f_n$ is efficiently computable because $f_n'$ and $h$ are both efficiently computable, and $h$ cannot be a hardcore bit for $f_n$ because $h(x)$ is trivially revealed in the output.

It's left to prove that $f_n$ is hard to invert, thus also a one-way function. Assume that there exists a non-uniform probabilistic polynomial-time adversary $A$ that inverts $f_n$ with non-negligible probability $\delta(n)$, that is,
$$
\Pr_{x \leftarrow \{0,1\}^n}\left[ A(1^n, f_n(x)) \in f_n^{-1}(f_n(x)) \right] \geq \delta(n).
$$

Now the algorithm $A'$ that inverts $f_n'$ is construct by, given $f_n'(x)$,
\begin{enumerate}
    \item For $r = 0, 1$, $A'$ guesses $h(x) = r$ and computes $x_r = A(1^n, f_n'(x)\| r)$.
    \item $A'$ checks if $f_n'(x_r) = f_n'(x)$ for $r = 0, 1$, if any one of the two equations holds, then output the corresponding $x_r$.
\end{enumerate}

Since one guess of $h(x) = r$ is correct, and $A$ succeeds with probability $\ge \delta(n)$, we can conclude that 
\begin{align*}
    \Pr_{x \leftarrow \{0,1\}^n}\left[ A'(1^n, f_n'(x)) \in (f_n')^{-1}(f_n'(x)) \right] & \geq \Pr_{x \leftarrow \{0,1\}^n}\left[ A(1^n, f_n'(x) \| h(x)) \in (f_n')^{-1}(f_n'(x)) \right] \\
    & \geq \Pr_{x \leftarrow \{0,1\}^n}\left[ A(1^n, f_n'(x) \| h(x)) \in f_n^{-1}(f_n(x)) \right] \\
    & \geq \delta(n).
\end{align*}
Hence, we can invert $f_n'$ with non-negligible probability, contradicting that $f_n'$ is a one-way function.

In conclusion, no deterministic function $h$ can be a universal hardcore bit.