\section*{Problem 4}

We first change the discreption of the problem. If $\mathsf{Exp}$ is not a strong one-way function, then there must exists an adversary $\mathcal{A}$ and a polynomial $r(n)$ that for any input $G_n$ which is in binary representation, we have 
\[
   \Pr\{a\in \mathbb{Z}_{p_n}, \mathsf{Exp}(\mathcal{A}(G_n,g_n^a))=g_n^a\}\ge \frac{1}{r(n)}.
\]
We can see that in a group, $\mathsf{Exp}(\mathcal{A}(G_n,g_n^a))=g_n^a$ implies $\mathcal{A}(G_n,g_n^a)=a$. Other notice is that we can assume $\mathcal{A}$ to be deterministic, since whenever $\mathcal{A}$ takes random bits $r$, there must exists $r_0$ such that
\[
   \Pr\{a\in \mathbb{Z}_{p_n}, \mathcal{A}_{r_0}(G_n,g_n^a)=a\}\ge \frac{1}{r(n)},
\] 
and we can replace $\mathcal{A}$ by $\mathcal{A}_{r_0}$. Now the probability inequality means that for at least $\frac{p_n}{r(n)}$ different values of $a$, the adversary can easily compute $\mathcal{A}(G_n,g_n^a)=a$. We aim to prove that $\mathsf{Exp}$ is not a weak one way function under the assumption that $\mathsf{Exp}$ is not a strong one-way function, by the same reason discribed above, it's sufficient to prove that for all polynomial $q$, there exists an adversary $\mathcal{A}'$ such that 
\[
   \Pr\{a\in \mathbb{Z}_{p_n}, \mathcal{A}'(G_n,g_n^a)=a\}\ge 1-\frac{1}{q(n)}.
\] 

The new adversary is that, for an input $g=g_n^{a^*}$, at an iteration we sample $x\in \{1,2,\cdots,p_n-1\}$ and check if $\mathsf{Exp}(\mathcal{A}(G_n,g^x))=g^x$, if so, we output $a=\frac{1}{x}\mathcal{A}(G_n,g^x)$; otherwise we abort this iteration and repeat. We only perform $O(r(n)\log q(n))$ iterations, if all iterations abort, the algorithm fails and output abitrarily. 

Now since for a fraction of $\frac{1}{r(n)}$ inputs the adversary $\mathcal{A}$ can compute $\mathcal{A}(G_n,g_n^a)=a$, so for a fraction of $\frac{1}{r(n)}$ different $x$ the adversary $\mathcal{A}'$ will meet $g^x=g_n^{a^*x}=g_n^{a}$ and finally correctly compute $a^*$. That implies the probability of failing in computing $a^*$ is at most
\[
   \left(1-\frac{1}{r(n)}\right)^{O(r(n)\log q(n))}=\frac{1}{q(n)},
\]
as desired.
