\subsection{Problem 2}
Consider three hybrids:
\begin{itemize}
    \item $H_0$: Outputs $L^n(x)$.
    \item $H_1$: Outputs $G^n(x)\oplus(0^{2n-1}\|r)$.
    \item $H_2$: Outputs $U^{2n}$.
\end{itemize}
Now we prove $H_0$ is indistinguishable from $H_2$.

\noindent\textbf{Step 1.} We first prove $H_0$ is indistinguishable from $H_1$ by contradiction. Assume there is an adversary $\mathcal A$ that
$$\left|\Pr_{x\gets\{0,1\}^n}[\mathcal A(L^n(x))=1]-\Pr_{x\gets\{0,1\}^n,r\gets\{0,1\}}[G^n(x)\oplus(0^{2n-1}\|r)]\right|\geq 1/\poly(n),$$
We are going to construct an adversary that distinguishes the hard-core bit $h^n(x)$ from uniform.

Define a PPT algorithm $\mathcal B$ as follows: 
\begin{itemize}
    \item[]\textbf{Algorithm} $\mathcal B^{\mathcal A}(y\in\{0,1\}^{2n},b\in\{0,1\})$:
    \item Output $\mathcal A(y\oplus(0^{2n-1}\|b))$.
\end{itemize}
When $b$ is the hardcore bit $h^n(x)$, we have $\mathcal B$ gives $L^n(x)$ to $\mathcal A$, which corresponds to $H_0$; when $b$ is a random bit $r\gets\{0,1\}$, we have $\mathcal B$ gives $G^n(x)\oplus(0^{2n-1}\|r)$ to $\mathcal A$, which corresponds to $H_1$. Thus,
\begin{align*}
    &\left|\Pr_{x\gets\{0,1\}^n}[\mathcal B^{\mathcal A}(G(x),h^n(x))]-\Pr_{x\gets\{0,1\}^n,r\gets\{0,1\}}[\mathcal B^{\mathcal A}(G(x),r)]\right|\\
    =&\left|\Pr_{x\gets\{0,1\}^n}[\mathcal A(L^n(x))=1]-\Pr_{x\gets\{0,1\}^n,r\gets\{0,1\}}[G^n(x)\oplus(0^{2n-1}\|r)]\right|\geq 1/\poly(n)
\end{align*}
That is, $\mathcal B$ distinguishes the hard-core bit of $G^n(x)$ from uniform, which contradicts the definition of the hardcore bit.

\noindent\textbf{Step 2.} We then prove $H_1$ is indistinguishable from $H_2$ by contradiction.
Assume there is an adversary $\mathcal A'$ that
$$\left|\Pr_{x\gets\{0,1\}^n,r\gets\{0,1\}}[\mathcal A'(G^n(x)\oplus(0^{2n-1}\|r))]-\Pr_{u\gets\{0,1\}^{2n}}[\mathcal A'(u)=1]\right|\geq 1/\poly(n),$$
We are going to construct an adversary that distinguishes $G^n(x)$ from uniform.
Define a PPT algorithm $\mathcal B'$ as follows: 
\begin{itemize}
    \item[]\textbf{Algorithm} $\mathcal B'^{\mathcal A'}(y\in\{0,1\}^{2n})$:
    \item Sample a random bit $r\gets\{0,1\}$
    \item Output $\mathcal A'(y\oplus(0^{2n-1}\|r))$.
\end{itemize}
When $y$ is $G^n(x)$, we have $\mathcal B'$ gives $G^n(x)\oplus(0^{2n-1}\|r)$ to $\mathcal A'$, which corresponds to $H_1$. When $y$ is a uniformly random string $u$, we have $\mathcal B'$ gives $u\oplus(0^{2n-1}\|r)$ (a random string) to $\mathcal A'$, which corresponds $H_2$. Thus,
\begin{align*}
    &\left|\Pr_{x\gets\{0,1\}^n,r\gets\{0,1\}}[\mathcal B'^{\mathcal A'}(G^n(x)) = 1] - \Pr_{u\gets\{0,1\}^{2n},r\gets\{0,1\}}[\mathcal B'^{\mathcal A'}(u) = 1]\right|\\
=&\left|\Pr_{x\gets\{0,1\}^n,r\gets\{0,1\}}[\mathcal A'(G^n(x)\oplus(0^{2n-1}\|r)) = 1] - \Pr_{u\gets\{0,1\}^{2n},r\gets\{0,1\}}[\mathcal A'(u\oplus(0^{2n-1}\|r)) = 1]\right|\\
=&\left|\Pr_{x\gets\{0,1\}^n,r\gets\{0,1\}}[\mathcal A'(G^n(x)\oplus(0^{2n-1}\|r)) = 1] - \Pr_{u\gets\{0,1\}^{2n}}[\mathcal A'(u) = 1]\right|\geq1/\poly(n).
\end{align*}
That is, $\mathcal B'$ distinguishes  $G^n(x)$ from uniform, which contradicts the pseudorandomness of $G(x)$.