\subsection{Problem 6}
For any input $x := x_1|x_2|\ldots|x_n$, we can split it into two halves: the left half $x_{[1:\lfloor n/2\rfloor]} := x_1|\ldots|x_{\lfloor n/2\rfloor}$, and the right half: $x_{[\lfloor n/2\rfloor+1:n]} = x_{\lfloor n/2\rfloor+1}|\ldots|x_n$. Define $L(x_{[1:n/2]}):=\prod_{i=1}^{n/2} M_{i,x_i}$, $R(x_{[\lfloor n/2\rfloor+1:n]}):=\prod_{i=\lfloor n/2\rfloor+1}^{n} M_{i,x_i}$, then the output of $f_k^n$ can be expressed as: 
\[
f_k^n(x)=(\prod_{i=1}^{n} M_{i,x_i})_{1,1} = \left(L(x_{[1:\lfloor n/2\rfloor]}) \cdot R(x_{[\lfloor n/2\rfloor+1:n]})\right)_{1,1}
\]
For any $s\in\{0,1\}^{\lfloor n/2\rfloor},t\in\{0,1\}^{\lceil n/2\rceil}$, define $VL(s)$ as the first row of $L(s)$ and $VR(t)$ as the first column of $R(t)$. Then we have: 
\[
f_k^n(s|t) = \langle VL(s), VR(t) \rangle.
\]
In the following we construct an adversary that, given access to an oracle $\mathcal O$, determines whether the oracle is $f_k^n$ or a uniformly random function.
\begin{itemize}
    \item []\textbf{Algorithm} $\mathcal{A}^{\mathcal O}$:
    \item Sample $n+1$ distinct left halves $s_1, s_2, \ldots, s_{n+1}\in\{0,1\}^{\lfloor n/2\rfloor}$, and $2n$ distinct right halves $t_1, t_2, \ldots, t_{n+1}\in\{0,1\}^{\lceil n/2\rceil}$.
    \item Construct an $(n+1) \times (n+1)$ matrix $M$ where $M_{i,j} = \mathcal O(s_i|t_j)$
    \item Compute $\text{rank}(M)$. If $\text{rank}(M)\leq n$, output $1$ (meaning the oracle is $f_k^n$). Otherwise, output $0$ (meaning the oracle is a uniformly random function.
\end{itemize}

Then, we analyze the behavior of $\mathcal{A}$.

\textbf{Case 1: the Oracle is a random function} \\
We have $M$ is a random $(n+1) \times (n+1)$ binary matrix. Therefore,
\[
\Pr[\text{rank}(M) = n+1] = \prod_{i=0}^{n}(1 - 2^{-(n+1-i)}) \geq 1/4+1/2^{n+2}
\]
The inequality ``$\geq$'' can be proved by induction. Therefore, $\mathcal A$ outputs $1$ with probability $\leq 3/4$.

\textbf{Case 2: the Oracle is $f_k^n$} \\
$M_{i,j} = \langle VL(s_i), VR(t_j) \rangle$ \\
Let $ML = [VL(s_1)^T | VL(s_2)^T | \ldots | VL(s_{n+1})^T]^T$ be a $(n+1) \times n$ matrix \\
Let $MR = [VR(t_1) | VR(t_2) | \ldots | VR(t_{n+1})]$ be an $n \times (n+1)$ matrix \\
Then $M = ML \cdot MR$ \\
Since $ML$ is $(n+1) \times n$ and $MR$ is $n \times (n+1)$, we have $$\text{rank}(M) \leq \min(n, n+1) = n$$
Therefore, $\mathcal A$ outputs $1$ with probability exactly $1$.

In conclusion, $\mathcal A$ distinguishes $f_k^n$ from uniform with an advantage at least $1/4$. Therefore, $F$ is not a PRF family.