%\section{Appendix and Further Topics}
\section{Ranked Enumeration of All $s,t$-Separators}
\label{sec:enumseps}
We present, in Figure~\ref{alg:EnumSep}, an algorithm that lists all (not necessarily minimal) $s,t$-separators of $G$ in ranked order by weight, 
where the secondary ranking is by distance to $s$. Formally, if $S_1,S_2$ are $s,t$-separators of $G$, then:
\begin{align}
	w(S_1){<}w(S_2) &\text{ or } \left(w(S_1){=}w(S_2) \text{ and } S_1 {\preceq} S_2\right) \Rightarrow \label{eq:rankedstSeps} \\
	&S_1 \text{ is listed before }S_2  \nonumber
\end{align}
Due to space restrictions, the proofs of this section are deferred to Section~\ref{sec:enumsepsAppendix} of the Appendix.
 
We begin by characterizing minimal $s,t$-separators that exclude a subset $U \subseteq \nodes(G)$ of vertices. 
We define: $\minlsepEst{G}{U}\eqdef \set{S \in \minlsepst{G}: S \subseteq \nodes(G){\setminus} U}$.
\eat{
\begin{equation}
	\label{eq:MinSepGIU}
	\minlsepEst{G}{U}\eqdef \set{S \in \minlsepst{G}: S \subseteq \nodes(G){\setminus} U}
\end{equation}
}
\eat{
Let $u \in \nodes(G)$; we denote by $\sat(G,u)$ the graph that results from $G$ by adding edges between all vertices in $N_G[u]$. In other words, $\sat(G,u)$ is the graph where the set $N_G[u]$ has been \e{saturated}, and forms a clique. Formally, $\nodes(\sat(G,u))\eqdef \nodes(G)$, and $\edges(\sat(G,u))\eqdef \edges(G)\cup\set{(x,y): x,y\in N_G(u)}$.
For a set of vertices $U \subseteq \nodes(G)$, we denote by $\sat(G,U)$ the graph that results by adding edges between all vertices in $N_G[u]$ for all $u\in U$. Formally, $\nodes(\sat(G,U))=\nodes(G)$ and 
\begin{equation}
	\label{eq:ESatG}
	\edges(\sat(G,U))\eqdef\edges(G)\cup \mathop{\textstyle\bigcup}_{u\in U}\set{(x,y):x,y \in N_G[u]}.
\end{equation}
}
\eat{
For a single vertex $u\in \nodes(G)$, we denote $\minlsepEst{G}{u}\eqdef \minlsepEst{G}{\set{u}}$.}
%In Section~\ref{sec:enumsepsAppendix} of the Appendix, we prove:
\def\MinlSepIU{
 $\minlsepEst{G}{U}=\minlsepst{\sat(G,U)}$.
	\eat{
	\begin{align*}
		\minlsepEst{G}{U}&=\minlsepst{\sat(G,U)} \\
		\minsep_{st}(G,\comp{U})& =\minsep_{st}(\sat(G,U))
	\end{align*}
}
}
\begin{theorem}
	\label{thm:MinlSepIU}
	\MinlSepIU
\end{theorem}
\eat{
We denote by $\kappa_{s,t}(G,\comp{U})$ the minimum size of any minimal $s,t$-separator that excludes $U$. 
\begin{equation}
	\label{eq:kappaIncludeExclude}
	\kappa_{s,t}(G,\comp{U})\eqdef\min\set{|S| : S \in \minlsepEst{G}{U}}
\end{equation}
We denote by $\minsep_{s,t}(G,\comp{U})$ the subset of $\minlsepEst{G}{U}$ that have the smallest cardinality. Formally:
\begin{equation}
	\label{eq:MinimumIncludeExcludeFixed}
	\minsep_{s,t}(G,\comp{U})\eqdef\set{S\in \minlsepEst{G}{U} : |S|=\kappa_{s,t}(G,\comp{U})}
\end{equation}
}

Algorithm \algname{RankedEnumSeps} of Figure~\ref{alg:EnumSep} applies the Lawler technique with inclusion and exclusion constraints (e.g., see~\cite{DBLP:journals/pvldb/GolenbergKS11}), leading to a simple polynomial-delay algorithm. By applying Theorem~\ref{thm:uniqueMinClosest}, it easily follows that the delay of the algorithm is $O(Kn\cdot T(n,m))$ where $K$ is the size of the largest $s,t$-separator printed by the algorithm, and $T(n,m)$ is the time to compute a minimum-weight $s,t$-separator. \eat{Formal proofs for this and for the correctness of the algorithm are deferred to the full version of this paper.}

\begin{algseries}{H}{Algorithm for enumerating all $s,t$-separators in ranked order by weight, and distance from $s$.\label{alg:EnumSep}}	
	\begin{insidealg}{RankedEnumSeps}{$G$, $\set{s,t}$}					
		\STATE Compute $S\in \minsep_{s,t}(G)$ closest to $s$ \COMMENT{Thm.~\ref{thm:uniqueMinClosest}}
		\STATE $Q\gets \algname{PriorityQueue}(\texttt{card}, \preceq)$
		\STATE $Q.\mathrm{push}(\triple{G}{S}{I=\emptyset})$ \label{line:push1}
		\WHILE{$Q\neq \emptyset$}
		\STATE $\triple{G}{S}{I} \gets Q.\mathrm{pop}()$	
		\STATE \texttt{Print }$S$
		\FORALL{$v_i \in S{\setminus} I=\set{v_1,\dots,v_q}$} \label{line:rankedstSepsBeginFor}
			\STATE $I_i\gets I\cup \set{v_1,\dots, v_{i-1}}$
			\STATE $H\gets \sat(G,v_i)$ \COMMENT{Exclude $v_i$}
			\STATE $T{\in} \minsep_{s,t}(H\sminus I_i)$ closest to $s$ \COMMENT{Theorem~\ref{thm:uniqueMinClosest}}
			\STATE $Q.\mathrm{push}(\triple{H}{T\cup I_i}{I_i})$ \label{line:push2}
		\ENDFOR	 \label{line:rankedstSepsEndFor}
		%\STATE $I_i\gets I\cup \set{v_1,\dots, v_{i-1}}$
		\ENDWHILE
	\end{insidealg}
\end{algseries}
\def\thmPrintAll{
		Let $S$ be an $s,t$-separator of $G$. There exists an $s,t$-separator $S'$ printed by the algorithm where $S' \subseteq S$.
}
\begin{theorem}
	\label{thm:PrintAll}
\thmPrintAll
\end{theorem}
An immediate consequence of Theorem~\ref{thm:PrintAll} is that every $s,t$-separator $S$ is either printed or has a printed subset $S'\subset S$, ensuring no separator is lost. Our approach efficiently produces the $K$  lightest $s,t$-separators first, making it a top-$K$ enumeration algorithm for $s,t$-separators.
\eat{
\begin{algseries}{H}{Algorithm for enumerating minimum-cardinality $s,t$-separators \label{alg:EnumSepMin}}
	\begin{insidealg}{MinimumSeps}{$G$, $\set{s,t}$}					
		\STATE Let $S$ be a min-cardinality $s,t$-separator of $G$
		\STATE $\kappa_{s,t}(G)\gets |S|$
		\STATE $Q \gets \emptyset$	
		\STATE $Q.\mathrm{push}(\triple{G}{S}{I=\emptyset})$  
		\WHILE{$Q\neq \emptyset$}
		\STATE $\triple{G}{S}{I} \gets Q.\mathrm{pop}()$	
		\STATE \texttt{Print }$S$
		\FORALL{$v_i \in S{\setminus}                                                                                                                                       I=\set{v_1,\dots,v_q}$}
		\STATE $I_i\gets I\cup \set{v_1,\dots, v_{i-1}}$
		\STATE $H\gets \sat(G,v_i)$ \COMMENT{Exclude $v_i$ (see Lemma~\ref{lem:MinlSepIU})}
		\STATE $T\gets$ minimum $s,t$-separator of $H\sminus I_i$		
		\IF{$|T|=\kappa_{s,t}(G)-|I_i|$} 
		\STATE $Q.\mathrm{push}(\triple{H}{T}{I_i})$ \COMMENT{See Corollary~\ref{corr:vertexSetInclude}}
		\ENDIF	
		\ENDFOR	
		\ENDWHILE
	\end{insidealg}	
\end{algseries}
}
