Problem A
Deterministic Finite Automata - Minimum Word Length
Languages
en
is
You are given a deterministic finite automaton that accepts the language $\mathcal{L}$. You should output the length of the shortest word $w$ such that $w \in \mathcal{L}$ is a finite language. You may assume that $\mathcal{L}$ is non-empty.
Input
The input contains the description of a deterministic finite automaton.
The first line contains four positive integers $n$, $c$, $s$, and $f$, where $n$ is the number of states, $c$ is the size of the alphabet, $s$ is the initial state, and $f$ is the number of final states. The second line consists of a string $\Sigma = \Sigma _1\Sigma _2\dots \Sigma _c$ of $c$ distinct symbols, each of which is a lowercase english character. The third line consists of $f$ distinct positive integers, the set of final states. Then $n$ lines follow, each with $c$ positive integers, describing the symbol table. The $j$-th integer on the $i$-th of those lines represents the state transitioned to from state $i$ upon reading $\Sigma _j$.
Each state is an integer between $1$ and $n$. It is guaranteed that $1 \leq n \leq 10\, 000$, $1 \leq s \leq n$, and $0 \leq f \leq n$.
Output
Output the length of the shortest word in $\mathcal{L}$.
Sample Input 1 | Sample Output 1 |
---|---|
4 2 1 2 ab 2 4 2 3 3 2 3 3 1 2 |
1 |
Sample Input 2 | Sample Output 2 |
---|---|
4 4 1 2 acgt 1 2 2 2 2 2 3 3 3 3 4 4 3 4 3 3 3 4 |
0 |