\subsection{Problem 4} For any oracle $\mathcal{O}:\{0,1\}^n\to \{0,1\}$, and any oracle-aided PPT algorithm $D$, define the distinguishing advantage
\[
\mathrm{Adv}^{\mathcal{O}}_D(n):= \left|\Pr[D^{\mathcal{O}}(1^n) = 1] - \Pr[D^R(1^n) = 1]\right|,
\]
where $R$ denotes a uniform random function $R \colon \{0, 1\}^n \to \{0, 1\}$.
Suppose, towards contradiction, that there exists a p.p.t. adversary $\mathcal{A}$ and a polynomial $p$ such
that for infinitely many $n$
\[
\mathrm{Adv}_{\mathcal{A}}^{H^n}(n) \geq \frac{1}{p(n)}. \quad (1)
\]
Define two polynomial-time distinguishers $\mathcal{B}_\mathcal{F}$ and $\mathcal{B}_\mathcal{G}$.

\textbf{Algorithm $\mathcal{B}_\mathcal{F}^\mathcal{A}$}
\textbf{Input:} oracle $\mathcal{O} \colon \{0,1\}^n \to \{0,1\}$ (either $f_j$ for random $j$ or a uniform random function).
\begin{enumerate}
    \item Draw a random key $k \leftarrow \mathcal{K}_n$ and obtain the program of $g_k$.
    \item When $\mathcal{A}$ asks a query $x \in \{0,1\}^n$, return $\mathcal{O}(x) \oplus g_k(x)$.
    \item Output whatever $\mathcal{A}$ outputs.
\end{enumerate}

\textbf{Analysis of $\mathcal{B}_\mathcal{F}$.} If $\mathcal{O} = f_j$ then the oracle seen by $\mathcal{A}$ is $h_{(j,k)}$ exactly. If $\mathcal{O} = R$ is uniform, the
answers are $R(x) \oplus g_k(x)$. For every fixed $x$ the bit $R(x)$ is uniform and independent of $g_k(x)$,
hence $R(x)\oplus g_k(x)$ is uniform; furthermore, the bits for distinct inputs remain independent. Thus
the oracle is a uniform random function. Consequently
\[
\mathrm{Adv}_{\mathcal{B}_\mathcal{F}}^{F^n}(n) = \mathrm{Adv}_{\mathcal{A}}^{H^n}(n) \geq \frac{1}{p(n)}. \quad (2)
\]

\textbf{Algorithm $\mathcal{B}_\mathcal{G}^\mathcal{A}$:}
The construction is similar: receive oracle $\mathcal{O}$ (either $g_k$ or random), draw $j \leftarrow \mathcal{J}_n$, answer $f_j(x) \oplus \mathcal{O}(x)$.
Exactly the same argument shows
\[
\mathrm{Adv}_{\mathcal{B}_\mathcal{G}}^{G^n}(n) = \mathrm{Adv}_{\mathcal{A}}^{H^n}(n) \geq \frac{1}{p(n)}. \quad (3)
\]

\textbf{Contradiction:} If $\mathcal{F}$ is a PRF family then, by definition, every p.p.t. distinguisher has negligible
advantage against it, contradicting (2). If $\mathcal{G}$ is a PRF family the same contradiction arises from (3).
Because the premise guarantees that one of the two families is a PRF family, the assumption that (1)
holds is impossible.

Therefore no PPT adversary can achieve a non-negligible advantage against $H$, and the
family $\mathcal{H} = \{h^n_{(j,k)}\}_n$ is a pseudorandom-function family.