World's most popular travel blog for travel bloggers.

[Solved]: Finding Kernel in DAG

, , No Comments
Problem Detail: 

Let $G=(V,E)$ be a DAG. A subset $A \subseteq V$ is called a kernel if for all $u,v \in A$ $uv \notin E$ and for all $v \in V-A$ there exists an $a \in A$ such that $av \in E$ (note again, this is a directed graph).

I need to find an algorithm that runs in $O(V+E)$ that upon giving a DAG $G$, would find a kernel in the graph.

I started like this:

Sort the graph toplogically. Such a sorting exists since it is a DAG. Let us mark the output as $v_1, v_2,...,v_n$. Then we run right to left:

If $v_n$ has no ingoing edges, we add it to our kernel set $K$. Else, here I got stuck.

Maybe dynamic programming can help us here?

Asked By : TheNotMe

Answered By : Billiska

Let's start the algorithm with these 3 sets:

  • $V$ = {all vertices}
  • $K$ = {}
  • $K'$ = {}

with the semantics:

  • $V$ stores unprocessed vertices
  • $K$ stores vertices known to be in the kernel
  • $K'$ stores vertices known to be outside the kernel

You're right that all vertices without incoming edges always belongs to the kernel. Add the them to the set $K$ & remove from $V$.

The next step is realizing that any vertices that can be immediately reached from vertices in the current $K$ must be outside the kernel. Add these to $K'$ & remove from $V$.

Now, all the vertices that is left in $V$ without incoming edges (from other vertices inside $V$) again can be added to $K$ (and remove from $V$).

...

Repeat the process until $V$ is empty.

Best Answer from StackOverflow

Question Source : http://cs.stackexchange.com/questions/28402

0 comments:

Post a Comment

Let us know your responses and feedback