\section{Listing Cost-Constrained Minimal $s,t$-Separators in FPT-Delay}
\label{sec:theAlg}
In this section, we consider the case where the weight function $w:\nodes(G)\rightarrow \set{1,\dots,c}$ is bounded by a constant $c$. That is, $w(v)\leq c$ for all 
$v\in \nodes(G)$.
We present an algorithm that given a threshold value $W$, returns all minimal $s,t$-separators $S\in \minlsepst{G}$ where $w(S)\leq W$ in ranked order by their distance from $s$. That is, if $S_1,S_2\in \minlsepst{G}$ where $w(S_1)\leq W$, $w(S_2)\leq W$, and $S_1 \prec S_2$, then $S_1$ is printed before $S_2$ by the algorithm. To that end, we first transform $G$ into an unweighted graph $G'$ by using the common vertex-splitting technique that preserves $G$'s paths and connectivity structure. For every vertex $v\in \nodes(G)$, we generate a set $C_v$ of $w(v)\leq c$ copies of $v$ in $G'$ and connect them to form a clique. Let $a',b'\in \nodes(G')$ be copies of distinct vertices $a,b\in \nodes(G)$, respectively. Then $(a',b')\in \edges(G')$ if and only if $(a,b)\in \edges(G)$. It is easily seen that $S\in \minlsepst{G}$ if and only if $S'\in \minlsepst{G'}$, where $S'\eqdef \cup_{v\in S}C_v$. Note also that $|S'|=w(S)$. Hence, the problem is reduced to that of returning all minimal $s,t$-separators of $G'$ whose \e{cardinality} is at most $W$ in ranked order by their distance from $s$. The rest of this section is devoted to this problem.


For any natural number $k\geq 0$, we denote by $\minlsepstk{G}$ the minimal $s,t$-separators whose cardinality is at most $k$. 
\begin{equation}
	\label{eq:lessThank}
	\minlsepstk{G}\eqdef \set{S\in \minlsepst{G}: |S|\leq k}
\end{equation}
Let $C_1,C_2 \subseteq \nodes(G)$. We say that they are \e{incomparable} if $C_1\not\subseteq C_2$ and $C_2\not\subseteq C_1$. Recall Definition~\ref{def:order} of the partial order $\preceq$ between minimal $s,t$-separtors.\eat{ 
We define a partial order $\preceq$ over the members of $\minlsepst{G}$. 
Let $S,T\in \minlsepst{G}$. We say that \e{$S$ is closer to $s$ than $T$}, in notation $S \prec T$, if and only if $C_s(G\sminus S)\subset C_s(G\sminus T)$, and that $S\preceq T$  if and only if $C_s(G\sminus S)\subseteq C_s(G\sminus T)$.} In Figure~\ref{fig:rankedMinSeps}, we present the enumeration algorithm that lists all minimal $s,t$-separators whose size is at most $k$ (i.e., $\minlsepstk{G}$) according to the order $\prec$. Recall that $\impsepstk{G}$ is the set of important minimal $s,t$-separators of size at most $k$ (see Section~\ref{sec:importantSeps}). 

\eat{
We define the subset of $\minlsepstk{G}$, which are closest to $s$ as follows:
\begin{equation}
	\label{eq:leftomostseps}
	\leftsepstk{G}\eqdef\set{S\in \minlsepstk{G} : \forall S'\in \minlsepst{G}: \text{if } S'\prec S \text{ then } |S'|>k}
\end{equation}
In Section ??, we present an algorithm that enumerates the set $\leftsepstk{G}$ in total time $O^*(4^k)$. We now present the enumeration algorithm.
\begin{lemma}
	Let $T$ be a minimum $s,t$-separator of $G$ that is closest to $s$. For every $S\in \leftsepstk{G}$, it holds that $S\subseteq T\cup C_s(G\sminus T)$.
\end{lemma}
}


\begin{algserieswide}
	{t}{Algorithm for listing the minimal $s,t$-separators of $G$ whose size is at most $k$, ranked by $\preceq$. \label{fig:rankedMinSeps}}
	\begin{insidealgwide}{SmallMinimalSeps}{$G$, $s$, $t$, $k$}
		\REQUIRE{\text{Graph }$G$, and $s,t,\in \nodes(G)$.}
		\ENSURE{$\minlsepstk{G}$.}
		\IF{$(s,t)\in \edges(G)$}
			\STATE Print $\bot$
			\RETURN
		\ENDIF
		\STATE $Q\gets \algname{PriorityQueue}(\preceq)$, $\M \gets \emptyset$
		\STATE Compute $\impsepstk{G}$ \COMMENT{Theorem~\ref{thm:importantSepsEnum}} \label{line:importantCompute1}
		\eat{\STATE Compute $\impsepstk{G}$ \COMMENT{Takes time $O(n\cdot T(n,m)\cdot 4^k)$ (see Theorem~\ref{thm:importantSepsEnum})}}
		\FOR{$S\in \impsepstk{G}$}
			\STATE $Q.\texttt{push}(S)$ \label{line:pushImportantG}
		\ENDFOR  \label{line:importantComputePushEnd}
		\WHILE{$Q$ is not empty}
			\STATE $S\gets Q.\texttt{pop}()$ \label{line:popQ}
			\STATE Print $S$ \label{line:printS}
			\STATE $\M.\texttt{push}(S)$
			\STATE Define $H_S$: $\nodes(H_S){=}\set{s}{ \cup} S{\cup} C_t(G\sminus S)$, $\edges(H_S){=}\edges(G[\nodes(H_S)]){\cup} \set{(s,v):v{\in} S}$ \label{line:generateHS} \eat{\COMMENT{Note: $S{=}N_{H_S}(s)$}}
			\FOR{$v\in S$} \label{line:startFor}
				\STATE Let $H_S^v$ be the graph that results from $H_S$ by contracting the edge $(s,v)$ to $s$. \label{line:HContractv}
				\STATE Compute $\impsepstk{H_S^v}$  \COMMENT{Theorem~\ref{thm:importantSepsEnum}}
				%\STATE Compute $\leftsepstk{H_S^v}$
				\FOR{$T\in \impsepstk{H_S^v}$}
				%\FOR{$T\in \leftsepstk{H_S^v}$}
				\IF{$T\notin Q$ AND $T\notin \M$}
					\STATE $Q.\texttt{push}(T)$ \label{line:pushQ}
				\ENDIF
				\ENDFOR
			\ENDFOR \label{line:endFor}
		\ENDWHILE	
	\end{insidealgwide}
\end{algserieswide}
\subsection{Overview of Proof of Correctness}
\label{sec:algCorrectness}
Correctness is established by showing that 
a subset $S\subseteq \nodes(G)$ is printed by the algorithm if and only if $S\in \minlsepst{G}$, and $|S|\leq k$ (i.e., $S\in \minlsepstk{G}$). 
This is established by Theorems~\ref{thm:onlyLessThank} and~\ref{thm:mainCorrectness}.
In Theorem~\ref{thm:MinlSepsOrder}, we show that if $S_1,S_2 \in \minlsepstk{G}$, and $S_1 \prec S_2$, then $S_1$ is printed before $S_2$. Finally, we establish FPT-delay in Theorem~\ref{thm:runtime}. The results follow from a series of lemmas.
%Due to the space restriction, the proofs of this section are deferred to Section~\ref{sec:proofsForEnumerationAlg} of the Appendix. 

%To that end, we require the following technical lemmas, whose proofs are deferred to Section~\ref{sec:proofsForEnumerationAlg} of the Appendix. 
\def\lemContract{Let $v\in N_G(s)$, and let $G'$ denote the graph that results from $G$ by contracting the edge $(s,v)$ to $s$. Then $\minlsepst{G'}=\set{S\in \minlsepst{G}: v\notin S}$. }

\eat{
\begin{lemma}
	\label{lem:contract}
	\lemContract
\end{lemma}
}

\def\lemParallel{
	Let $S,T\in \minlsepst{G}$. Then:
	\begin{align*}
		C_s(G\sminus S) \subseteq C_s(G\sminus T) \text{ if and only if } T\subseteq S\cup C_t(G\sminus S).
	\end{align*}
}

\eat{
\begin{lemma}
	\label{lem:parallel1}
	\lemParallel
\end{lemma}
}

\def\lemHgraph{
	Let $S\in \minlsepst{G}$, and let $H_S$ be the graph that results from $G$ by adding all edges from $s$ to $S$. That is, $\edges(H_S)=\edges(G)\cup \set{(s,v):v\in S}$. Then:
	\begin{align*}
		\minlsepst{H_S}=\set{Q\in \minlsepst{G}: Q\subseteq S\cup C_t(G\sminus S)}
	\end{align*}
}

\eat{
\begin{lemma}
	\label{lem:Hgraph}
	\lemHgraph
\end{lemma}
}

\def\thmonlyLessThank{If $S\subseteq \nodes(G)$ is printed, then $S\in \minlsepstk{G}$, and $S$ is printed exactly once.}
\begin{theorem}
	\label{thm:onlyLessThank}
\thmonlyLessThank
\end{theorem}
\eat{
\begin{proof}
\eat{Every subset of vertices that is inserted into the queue (in lines~\ref{line:pushImportantG} and~\ref{line:pushQ}) is pushed into the queue exactly once, and has cardinality at most $k$. }Every subset of vertices inserted into the queue (in lines~\ref{line:pushImportantG} and~\ref{line:pushQ}) is pushed exactly once and has cardinality at most $k$.
Therefore, we only need to show that every subset of vertices pushed into the queue $Q$, and printed by the algorithm, belongs to $\minlsepst{G}$.
Suppose, by way of contradiction, that this is not the case, and let $T\subseteq \nodes(G)$ be the first subset of vertices printed where $T\notin \minlsepst{G}$. Then $T$ must be inserted into the queue in line~\ref{line:pushQ}. Consider the set $S$ that was printed before $T$ is inserted into the queue. By our assumption $S\in \minlsepst{G}$. Therefore, $T\in \impsepstk{H_S^v}$, where $v\in S$. By Lemma~\ref{lem:Hgraph}, $\minlsepst{H_S}\subseteq \minlsepst{G}$. Since $v\in N_{H_S}(s)$, and $H_S^v$ is the graph that results from $H_S$ by 
contracting the edge $(s,v)$ to vertex $v$, by Lemma~\ref{lem:contract}, it holds that $\minlsepst{H_S^v}\subseteq \minlsepst{H_S}\subseteq  \minlsepst{G}$. 
Since $T\in \impsepstk{H_S^v}\subseteq \minlsepst{H_S^v}$, we get that $T\in \minlsepst{G}$, which brings us to a contradiction.
\end{proof}
}

\def\thmmainCorrectness{
	Let $T\in \minlsepstk{G}$. Then $T$ is printed by \algname{SmallMinimalSeps} in Figure~\ref{fig:rankedMinSeps}.
}
\begin{theorem}
	\label{thm:mainCorrectness}
	\thmmainCorrectness
\end{theorem}
\eat{
	\begin{proof}
		If $T\in \impsepstk{G}$, then $T$ is inserted into the queue in line~\ref{line:pushImportantG}, and will be printed. Therefore, assume that $T\notin \impsepstk{G}$.
		Suppose that $T$ is not printed. Let $T'\in \minlsepst{G}$ be the largest minimal $s,t$-separator, with respect to $\prec$, that is printed by the algorithm, such that $T'\preceq T$. In other words, there does not exist a $T''\in \minlsepst{G}$, that is printed by the algorithm where $T'\prec T''\preceq T$. By Lemma~\ref{lem:mainCorrectness}, and the fact that $T\notin \impsepstk{G}$ such a separator $T'$ exists.
		
		
		Since  $C_s(G\sminus T')\subset C_s(G\sminus T)$, then by Lemma~\ref{lem:parallel1}, it holds that $T\in T'\cup C_t(G\sminus T')$. By Lemma~\ref{lem:Hgraph}, it holds that $T\in \minlsepst{H_{T'}}$. Consider what happens when $T'$ is popped from the queue in line~\ref{line:popQ}, and the graph $H_{T'}$ is generated in line~\ref{line:generateHS}. Since $T\neq T'$ (we assume that $T$ is not printed), $T'\subseteq N_{H_{T'}}(s)$, and $T\in \minlsepst{H_{T'}}$, then there exists a vertex $v\in T'$, such that $T\in \minlsepst{H_{T'}^v}$ (see line~\ref{line:HContractv}). If $T\in \impsepstk{H_{T'}^v}$, then $T$ is pushed into the queue in line~\ref{line:pushQ}, and will therefore be printed. Otherwise, by Lemma~\ref{lem:mainCorrectness}, there exists an $S\in \impsepstk{H_{T'}^v}$, such that $C_s(H_{T'}^v\sminus S)\subseteq C_s(H_{T'}^v\sminus T)$. By construction, we have that  $C_s(H_{T'}\sminus T')\subset  C_s(H_{T'}^v\sminus S)\subseteq C_s(H_{T'}\sminus T)$. Since $S$ is pushed into the queue in line~\ref{line:pushQ}, then it will be printed by the algorithm in line~\ref{line:printS}. By Theorem~\ref{thm:onlyLessThank}, we have that $S\in \minlsepstk{G}$ is printed by the algorithm, where $T'\prec S \preceq T$, contradicting our assumption that $T'$ is maximal with respect to the partial order $\prec$.
	\end{proof}
}
Theorem~\ref{thm:onlyLessThank} and Theorem~\ref{thm:mainCorrectness} together establish that a subset $T\subseteq \nodes(G)$ is printed by the algorithm if and only if $T\in \minlsepstk{G}$. In other words, $\algname{SmallMinimalSeps}$ prints precisely the set $\minlsepstk{G}$.

\def\MinlSepsOrderthm{Let $S_1,S_2 \in \minlsepstk{G}$. If $S_1 \prec S_2$, then $S_1$ is printed before $S_2$ by Algorithm $\algname{SmallMinimalSeps}$.}
\begin{theorem}
	\label{thm:MinlSepsOrder}
	\MinlSepsOrderthm
\end{theorem}
Theorem~\ref{thm:MinlSepsOrder} establishes that the minimal $s,t$-separators are printed in an order that corresponds to the desirability of the adjustment sets, in terms of their variance (see Section~\ref{sec:OrderingAdjSets}).
\def\leftmostlem{
		Let $T\in \minlsepstk{G}$. Exactly one of the following holds: (1) $T\in \impsepstk{G}$ or (2) There exists a minimal $s,t$-separator $S\in  \impsepstk{G}$ such that $S\prec T$.
}
\eat{
\begin{lemma}
	\label{lem:leftmost}
	\leftmostlem
\end{lemma}
\begin{proof}
	By induction on $|C_s(G\sminus T)|$. If $|C_s(G\sminus T)|=1$, then clearly $T\subseteq N_G(s)$. By Lemma~\ref{lem:closeTos}, $T$ is the unique minimal $s,t$-separator that is closest to $s$, and hence $T\in \impsepstk{G}$.
	So, we assume that the claim holds for all $T\in \minlsepstk{G}$, where $1\leq |C_s(G\sminus S)|\leq \ell$. Let $T\in \minlsepstk{G}$, where $|C_s(G\sminus S)|=\ell +1$. If $T\in  \impsepstk{G}$, then we are done. Otherwise, if $T\notin  \impsepstk{G}$, then since $|T|\leq k$, it must hold that $T\notin \impsepst{G}$.
	By definition~\ref{def:importantSeps}, there exists a $T'\in \minlsepst{G}$ such that $T'\prec T$ (i.e., $C_s(G\sminus T')\subset C_s(G\sminus T)$), and $|T'|\leq |T|\leq k$. Consequently, $|C_s(G\sminus T')|< |C_s(G\sminus T)|=\ell +1$, and $|C_s(G\sminus T')| \leq \ell$. 
	Since $T'\in \minlsepstk{G}$ and $|C_s(G\sminus T')|\leq \ell$, then by the induction hypothesis, either $T' \in  \impsepstk{G}$, in which case $T' \prec T$, thus proving the claim. Otherwise, there exists an $S\in  \impsepstk{G}$ such that $S\prec T'$.
	Hence, $S\prec T' \prec T$, and $S \prec T$, thus proving the claim.
\end{proof}
}
\def\mainCorrectnesslem{
		Let $T\in \minlsepstk{G}$. There exists a $S\in \impsepstk{G}$ such that $S\preceq T$, and $T\subseteq S\cup C_t(G\sminus S)$.
}
\eat{
\begin{lemma}
	\label{lem:mainCorrectness}
	\mainCorrectnesslem
\end{lemma}
}
\eat{
\begin{proof}
	If $T\in \impsepstk{G}$, then the claim is immediate. If $T\notin \impsepstk{G}$ then, by Lemma~\ref{lem:leftmost}, there exists an $S\in \impsepstk{G}$, such that $S\prec T$.  By Lemma~\ref{lem:parallel1}, $T{\in} S{\cup} C_t(G\sminus S)$.
\end{proof}
}

%Theorem~\ref{thm:runtime} establishes the delay of the algorithm. The proof is deferred to Section~\ref{sec:proofsForEnumerationAlg} of the Appendix.
\def\runtimethm{
		The delay between the printing of minimal $s,t$-separators whose size is at most $k$ is $O(k^24^k(n+m))$.
}
\begin{theorem}
	\label{thm:runtime}
	\runtimethm
\end{theorem}
\eat{
\begin{proof}
	The size of the queue $Q$ and the data structure $\M$, can be at most $n^k$. We make the standard assumption that these data structures allow logarithmic insertion and extraction, which take time $O(k\log n)$. 
	Applying Theorem~\ref{thm:importantSepsEnum}, which states that there are at most $4^k$ important separators that can be found in time $O(k4^k(n+m))$, we get that the loop in lines~\eqref{line:startFor}-\eqref{line:endFor}
    runs in time:
	$
		O(k\cdot (n+4^k\cdot k \cdot (n+m) + k\cdot 4^k \cdot \log n)
	$.
	Overall, the delay is $O(4^kk^2(n+m))$.
\end{proof}
}

\eat{
\batya{Ignore the rest of this section. Not currently in use.}
\subsection{Minimal $s,t$-separators that are closest to $s$}
In this section, we present a procedure for enumerating the set $\leftsepstk{G}$, in time ??. We recall the definition 
of important minimal separators, whose size is at most $k$, denoted $\impsepstk{G}$,  in Section~\ref{sec:importantSeps}.
\begin{lemma}
	\label{lem:containmentImportant}
	The following holds: $\leftsepstk{G} \subseteq \impsepstk{G}$.
\end{lemma}
\begin{proof}
	Let $S\in \leftsepstk{G}$, and suppose that $S\notin \impsepstk{G}$. Since, by definition, $\impsepstk{G}=\impsepst{G}\cap \minlsepstk{G}$, this means that $S\notin \impsepst{G}$.
	This means that there exists a $T\in \minlsepst{G}$ such that $T\prec S$ and $|T|\leq |S|\leq k$. But then, $S\notin \leftsepstk{G}$, and we arrive at a contradiction.
\end{proof}


\begin{lemma}
	\label{lem:leftmostFrom}
	Let $T\in \minlsepstk{G}\setminus \leftsepstk{G}$. Let $H$ be the graph that results from $G$ by adding all the edges from $T$ to $t$. That is, $\edges(H)\eqdef \edges(G)\cup\set{(v,t): v\in T}$ Then $\leftsepstk{G}=\leftsepstk{H}$.
\end{lemma}
\begin{proof}
	By Lemma~\ref{lem:Hgraph}, we have that $\minlsepst{H}=\set{Q\in \minlsepst{G}:Q\subseteq T\cup C_s(G\sminus T)}=\set{T}\cup \set{Q\in \minlsepst{G}: Q\prec T}$. In particular, $\minlsepstk{H}=\set{T}\cup \set{Q\in \minlsepstk{G}: Q\prec T}$. 
	Let $S\in \leftsepstk{H}$. Since $\leftsepstk{H} \subseteq \minlsepstk{H}$, we have that $S\in \set{T}\cup \set{Q\in \minlsepstk{G}: Q\prec T}$.  If $S\notin \leftsepstk{G}$, then by definition~\eqref{eq:leftomostseps}, it holds that there exists a $S'\in \minlsepstk{G}$ such that $S'\prec S \preceq T$. Since $S'\in \minlsepst{H}$, we get a contradiction to the fact that $S\in \leftsepstk{H}$. Therefore,  $\leftsepstk{H} \subseteq \leftsepstk{G}$. 
	
	Now, take $S\in \leftsepstk{G}$. By Lemma~\ref{lem:leftmost}, we have that $S\prec T$, and hence $S\in \minlsepstk{H}$. If $S\notin \leftsepstk{H}$, then by definition~\eqref{eq:leftomostseps}, there exists a $S'\in \minlsepstk{H}$ such that $S'\prec S\prec T$. But this means that $S'\in \minlsepstk{G}$ where  $S'\prec S$, contradicting the fact that $S\in \leftsepstk{G}$. Therefore, $\leftsepstk{G} \subseteq \leftsepstk{H}$. 
\end{proof}

\begin{lemma}
	\label{lem:leftmostAlg}
	Let $T\in \minlsepstk{G}\setminus \leftsepstk{G}$, such that for every $S\in \minlsepstk{G}$ where $S\prec T$, it holds that $S\in \leftsepstk{G}$. In other words, $\leftsepstk{G}=\set{S\in \minlsepstk{G}: S\prec T}$. Let $H$ be the graph that results from $G$ by adding all edges between $T$ and $t$. Then the following holds:
	\begin{equation}
		\leftsepstk{G} \subseteq \impsepstk{H} \subseteq \leftsepstk{G} \cup \set{T} 
	\end{equation}
\end{lemma}
\begin{proof}
	By Lemma~\ref{lem:Hgraph}, we have that $\minlsepst{H}=\set{Q\in \minlsepst{G}:Q\subseteq T\cup C_s(G\sminus T)}=\set{T}\cup \set{Q\in \minlsepst{G}: Q\prec T}$. In particular, $\minlsepstk{H}=\set{T}\cup \set{Q\in \minlsepstk{G}: Q\prec T}$. By the assumption of the lemma, it holds that $\minlsepstk{H}=\set{T}\cup \leftsepstk{G}$. Clearly, $\impsepstk{H}\subseteq \minlsepstk{H}=\set{T}\cup \leftsepstk{G}$. 
	
	By Lemma~\ref{lem:leftmostFrom}, it holds that $\leftsepstk{G}=\leftsepstk{H}$. By Lemma~\ref{lem:containmentImportant}, it holds that $\leftsepstk{H}\subseteq  \impsepstk{H}$. Therefore, we get that $\leftsepstk{G}\subseteq  \impsepstk{H}$, as required.
\end{proof}
Lemmas~\ref{lem:leftmostFrom} and~\ref{lem:leftmostAlg} provide the foundation for a procedure for generating the set $\leftsepstk{G}$. The idea is to find the minimal $s,t,$-separator $T\in \minlsepstk{G}\setminus \leftsepstk{G}$, such that  $\leftsepstk{G}=\set{S\in \minlsepstk{G}: S\prec T}$, and then return the set $ \impsepstk{H}{\setminus}\set{T}$, where $H$ is the graph that results from $G$ by adding all edges between $T$ and $t$ (Lemma~\ref{lem:leftmostAlg}).
This is done in Algorithm \algname{ClosestTos}, presented in Figure~\ref{alg:leftmostk}. 

Algorithm \algname{ClosestTos} makes use of a procedure \algname{MinSepClosestTos} for finding the minimum $s,t$-separator that is closest to $s$. By Theorem~\ref{thm:smallestClosestTo}, this minimum $s,t$-separator is unique and can be found in time $O(n\cdot T(n,m))$. Let $S\in \minsepst{G}$ that is closest to $s$. If $|S|>k$, then $\kappa_{s,t}(G)>k$, and hence $\leftsepstk{G}=\emptyset$, which is returned in line~\ref{line:largerThank}. Otherwise, the algorithm finds the smallest-cardinality $T\in \minlsepst{G}$, such that $T\prec S$. Procedure \algname{SmallestSepLeftOf} in Figure~\ref{alg:SmallestSepLeftOf} returns the minimal $s,t$-separator $S_L$ such that $S_L=\arg\min_{|S'|}\set{S'\in \minlsepst{G}: S'\prec S}$. If $|S_L|>k$, then $S\in \leftsepstk{G}$, and is the unique minimal $s,t$-separator in $\leftsepstk{G}$, which is returned in line~\ref{line:single}. Otherwise, the algorithm repeatedly updates $S_L$ to a minimal $s,t$-separator that is closer to $s$, and has minimum size. This is repeated until $|S_L|>k$ in lines~\ref{line:while}-\ref{line:endwhile}. At this point, $P$ has the property that $P\in \minlsepstk{G}\setminus \leftsepstk{G}$, and $\leftsepstk{G}=\set{S\in \minlsepstk{G}: S\prec P}$. By Lemma~\ref{lem:leftmostAlg}, we have that $\leftsepstk{G} = \impsepstk{H}{\setminus}\set{P}$.
\begin{proposition}
	The runtime of algorithm \algname{ClosestTos} with input $G,s,t$, and $k$ is $O(\max\set{n,4^k}n\cdot T(n,m))$, where $T(n,m)$ is the time to find a single minimum separator in an undirected graph $G$ where $|\nodes(G)|=n$ and $|\edges(G)|=m$.
\end{proposition}
\begin{proof}
By Theorem~\ref{thm:smallestClosestTo}, finding the minimum $s,t$-separator closest to $s$ takes time $O(n\cdot T(n,m))$. Therefore, every call to \algname{SmallestSepLeftOf} with input $S\in \minlsepstk{G}$, will take time $O(k\cdot n \cdot T(n,m))$.
In every iteration of the loop in lines~\ref{line:while}-\ref{line:endwhile} the generated separator $S_L$ is closer to $s$. Therefore, the loop in lines~\ref{line:while}-\ref{line:endwhile}  takes time at most $O(n^2\cdot k\cdot T(n,m))$. By Theorem, generating the set $\impsepstk{H}$ takes time $O(n\cdot 4^k\cdot T(n,m))$. Overall, we get that the runtime of \algname{ClosestTos} is $O(n\cdot T(n,m)\cdot \max\set{4^k,nk})$.
\end{proof}


\renewcommand{\algorithmicrequire}{\textbf{Input:}}
\renewcommand{\algorithmicensure}{\textbf{Output:}}
\begin{minipage}{0.43\textwidth}
	\raggedleft
	\begin{algseries}{H}{\algname{SmallestSepLeftOf}. Receives as input the graph $G$, and an $S\in \minlsepst{G}$. Returns the smallest $T\in \minlsepst{G}$ such that $T\prec S$, if exists.\label{alg:SmallestSepLeftOf}}
		\begin{insidealg}{SmallestSepLeftOf}{$G$, $S$}
			\REQUIRE{\text{Graph }$G$, $S\in \minlsepst{G}$}
			\ENSURE{Smallest $T\in \minlsepst{G}$ s.t. $T\prec S$}
			\STATE \text{Construct }$H$\text{ from }$G$\text{ by adding edges }\\$\edges(H)\gets \edges(G)\cup \set{(v,t): v\in S}$ 
			\STATE $S_{\min}\gets \emptyset$
			\FORALL{$v \in S$}
			\STATE $\text{Construct }H_v$\text{ from }$H$\text{ by adding edges }\\$\edges(H_v)\gets \edges(H)\cup \set{(y,t): y\in N_H(v)}$ 
			\STATE $S_v\gets \algname{MinSepClosestTos}(H_v)$ 
			\IF{$S_{\min}=\emptyset$\text{ or }$|S_v|<|S_{\min}|$} 
			\STATE $S_{\min}\gets S_v$
			\ENDIF
			\ENDFOR
			\RETURN $S_{\min}$
		\end{insidealg}
	\end{algseries}
\end{minipage}
\hfill
\begin{minipage}{0.42\linewidth}
	\raggedright
	\begin{algseries}{H}{\algname{ClosestTos}. Returns the set $\leftsepstk{G}$. \label{alg:leftmostk}}
		\begin{insidealg}{ClosestTos}{$G$, $s$, $t$, $k$}
			\REQUIRE{\text{Graph }$G$, $s,t\in \nodes(G)$, $k>0$}
			\ENSURE{$\leftsepstk{G}$}
			\STATE$S\gets \algname{MinSepClosestTos}(G)$ \label{line:minsepclosest}
			\IF{$|S|>k$}
				\RETURN{$\emptyset$} \label{line:largerThank}
			\ENDIF
			\STATE $S_L\gets \algname{SmallestSepLeftOf}(G,S)$
			\IF{$(|S_L|>k)$} 
				\RETURN{$\set{S}$} \COMMENT{$S_L\in \leftsepstk{G}$}  \label{line:single}
			\ENDIF
			\STATE $P\gets \emptyset$ \label{line:initP}
			\WHILE{$(|S_L|\leq k)$} \label{line:while}
				\STATE $P\gets S_L$
				\STATE $S_L\gets \algname{SmallestSepLeftOf}(G,S_L)$
			\ENDWHILE \label{line:endwhile}
			\STATE \text{Construct }$H$\text{ from }$G$\text{ by adding all edges }\\$\edges(H)\gets \edges(G)\cup\set{(u,t):u\in P}$ \label{line:constructH}
			\RETURN $\impsepstk{H}{\setminus} \set{P}$ \label{line:returnByP}
		\end{insidealg}
	\end{algseries}
\end{minipage}


\begin{minipage}{0.42\linewidth}
	\raggedright
	\begin{algseries}{H}{\algname{ClosestTos}. Returns the set $\leftsepstk{G}$. \label{alg:leftmostk}}
		\begin{insidealg}{ClosestTos}{$G$, $s$, $t$, $k$}
			\REQUIRE{\text{Graph }$G$, $s,t\in \nodes(G)$, $k>0$}
			\ENSURE{$\leftsepstk{G}$}
			\STATE$S\gets \algname{MinSepClosestTos}(G)$ \label{line:minsepclosest}
			\IF{$|S|>k$}
				\RETURN{$\emptyset$} \label{line:largerThank}
			\ENDIF
			\STATE $S_L\gets \algname{SmallestSepLeftOf}(G,S)$
			\IF{$(|S_L|>k)$} 
				\RETURN{$\set{S}$} \COMMENT{$S_L\in \leftsepstk{G}$}  \label{line:single}
			\ENDIF
			\STATE $P\gets \emptyset$ \label{line:initP}
			\WHILE{$\true$} \label{line:while}
				\STATE $S_L'\gets  \algname{SmallestSepLeftOf}(G,S_L)$
				\IF{$|S_L'|\leq k$}
					\STATE $P\gets S_L$
					\STATE $S_L\gets S_L'$
				\ELSE
					\STATE {\bf BREAK}
				\ENDIF
			\ENDWHILE \label{line:endwhile}
			\STATE \text{Construct }$H$\text{ from }$G$\text{ by adding all edges }\\$\edges(H)\gets \edges(G)\cup\set{(u,t):u\in P}$ \label{line:constructH}
			\RETURN $\impsepstk{H}{\setminus} \set{P}$ \label{line:returnByP}
		\end{insidealg}
	\end{algseries}
\end{minipage}
}
