\begin{algorithm}[t]
\caption{Satisfaction-Driven Adaptive Filtering (SDAF)}
\label{alg:sdaf}
\begin{algorithmic}[1]

\Require Initial Candidate Set $\mathcal{S}$ (after Hard Constraints), Persona Constraints $\{C_p\}$, Importance $\{\alpha_p\}$.
\Statex \textbf{Initialize:} Create priority queues $Q_p$ for each persona $p$ (sorted by $\alpha$ descending) and set satisfaction $S_p \leftarrow 0$.

\While{any $Q_p$ is not empty}
    \State \textbf{Turn Selection:} Set $p^* \leftarrow \arg\min_{p \in P} S_p$ (break ties randomly).
    \State \textbf{Constraint Selection:} Pop top constraint $C_{curr}, \alpha_{curr}$ from $Q_{p^*}$.
    \State Set tentative set $\mathcal{S}' \leftarrow \mathcal{S} \cap C_{curr}$.
    
    \State \textbf{Validation:} Check feasibility via 2-step look-ahead:
    \Statex \quad \textit{Check 1 (Self):} $|\mathcal{S}'| > 0$
    \Statex \quad \textit{Check 2 (Global):} Other personas can still satisfy top constraints in $\mathcal{S}'$.
    
    \If{\textit{Check 1} is True \textbf{and} \textit{Check 2} is True}
        \State Update candidate set $\mathcal{S} \leftarrow \mathcal{S}'$ and score $S_{p^*} \leftarrow S_{p^*} + \alpha_{curr}$.
    \Else
        \State Discard $C_{curr}$ to preserve feasibility (score $S_{p^*}$ remains unchanged).
    \EndIf
\EndWhile
\State \textbf{Return} Final Optimized Candidate Set $\mathcal{S}$.
\end{algorithmic}
\end{algorithm}