After getting out from the Building of Secrets, BMP and MSA have uncovered the secret cheesecake formula. Unfortunately, the security at the factory is very angry with them. Wanting to avoid social interaction with the security guards, BMP and MSA must get away from the cheesecake factory and get back home safely.
The city BMP and MSA live in represents the worst urban planning you have ever seen, with  ~N~ intersections and
~N~ intersections and  ~M~ highways, going all over the place and taking up lots of valuable building land. However, that is not your concern right now, BMP and MSA has bribed you with TSSOJ points to help them get home safely!
~M~ highways, going all over the place and taking up lots of valuable building land. However, that is not your concern right now, BMP and MSA has bribed you with TSSOJ points to help them get home safely!
In an attempt to stop them, security has released their newest invention: the Giant Ant Dispenser on  ~W~ intersections. The dispenser will constantly dispense an infinite number of ants which will eat BMP and MSA in an instant. Obviously, BMP and MSA has instructed you to avoid all routes where you will run into the giant ants. Luckily, the giant ants will only travel along roads, but since there are an infinite number of ants, they will split off in all directions (but only along roads of course). In addition, ants are quite slow, as they only travel at 0.25 roads per second (meaning that every 4th turn, they will fully move along 1 road) while BMP's car travels at 1 road/second.
~W~ intersections. The dispenser will constantly dispense an infinite number of ants which will eat BMP and MSA in an instant. Obviously, BMP and MSA has instructed you to avoid all routes where you will run into the giant ants. Luckily, the giant ants will only travel along roads, but since there are an infinite number of ants, they will split off in all directions (but only along roads of course). In addition, ants are quite slow, as they only travel at 0.25 roads per second (meaning that every 4th turn, they will fully move along 1 road) while BMP's car travels at 1 road/second.
Just in case your program can't find a safe way home for BMP and MSA because of either ants blocking their route or because there is no path that will get them home safely, they have a backup plan of sacrificing bobhob314 and begging for mercy from the guards. But only if there is no safe way home (not because they want to save bobhob314 of course, but just in case they have to sacrifice him at some later time).
Note:
BMP and MSA always move immediately before the giant ants do. So if BMP and MSA are currently on an intersection that's about to be over run by ants the next turn, they are safe as long as they're moving to a safe intersection.
However, if BMP and MSA go to an intersection that's about to be overrun by giant ants right before they arrive, they get eaten!
Input Specification
The first line will contain  ~N~
~N~  ~(2 \le N \le 100)~ and
~(2 \le N \le 100)~ and  ~M~
~M~  ~(0 \le M \le 30)~.
~(0 \le M \le 30)~.
The next  ~M~ lines will have
~M~ lines will have  ~X~ and
~X~ and  ~Y~
~Y~  ~(1 \le X, Y \le N)~ representing a road between the 2 intersections.
~(1 \le X, Y \le N)~ representing a road between the 2 intersections.
The next line will have  ~W~
~W~  ~(0 \le W \le 15)~.
~(0 \le W \le 15)~.
The next  ~W~ lines will contain
~W~ lines will contain  ~W_i~, showing that intersection
~W_i~, showing that intersection  ~i~ contains a giant ant dispenser.
~i~ contains a giant ant dispenser.
Output Specification
Output a single integer, the length of the shortest path for BMP and MSA to get home from  ~1~ to
~1~ to  ~N~ while avoiding the ants.
~N~ while avoiding the ants.
If this is not possible, output sacrifice bobhob314.
Sample Input 1
8 7
1 2
2 3
3 4
4 5
5 6
6 7
6 8
1
7
Sample Output 1
sacrifice bobhob314
Explanation for Sample Output 1
Assume that the orange represents the intersections where the ants are, and the green is the location of BMP and MSA's car.
Initially there is a clear path from  ~1~ to
~1~ to  ~N~.
~N~.
\documentclass {standalone}
\usepackage {tikz}
\usetikzlibrary{positioning,shapes}
\begin {document}
 \resizebox{!}{4cm}{
  \begin {tikzpicture} [node distance=1mm and 8mm, piece/.style={ellipse,minimum width=10mm,draw=black,fill=white}]
   \node[piece] (A) [fill=green] {1};
   \node[piece] (B) [right=of A] {2};
   \node[piece] (C) [right=of B] {3};
   \node[piece] (D) [right=of C] {4};
   \node[piece] (E) [right=of D] {5};
   \node[piece] (F) [right=of E] {6};
   \node[piece] (G) [above right=1mm and 10mm of F,fill=orange] {7};
   \node[piece] (H) [below right=1mm and 10mm of F] {8};
   \draw (A) edge (B);
   \draw (B) edge (C);
   \draw (C) edge (D);
   \draw (D) edge (E);
   \draw (E) edge (F);
   \draw (F) edge (G);
   \draw (F) edge (H);
  \end{tikzpicture}
 }
\end{document}
However after 4 turns the ants spread from intersection  ~7~ to intersection
~7~ to intersection  ~6~.
~6~.
\documentclass {standalone}
\usepackage {tikz}
\usetikzlibrary{positioning,shapes}
\begin {document}
 \resizebox{!}{4cm}{
  \begin {tikzpicture} [node distance=1mm and 8mm, piece/.style={ellipse,minimum width=10mm,draw=black,fill=white}]
   \node[piece] (A) [] {1};
   \node[piece] (B) [right=of A] {2};
   \node[piece] (C) [right=of B] {3};
   \node[piece] (D) [right=of C] {4};
   \node[piece] (E) [right=of D,fill=green] {5};
   \node[piece] (F) [right=of E,fill=orange] {6};
   \node[piece] (G) [above right=1mm and 10mm of F,fill=orange] {7};
   \node[piece] (H) [below right=1mm and 10mm of F] {8};
   \draw (A) edge (B);
   \draw (B) edge (C);
   \draw (C) edge (D);
   \draw (D) edge (E);
   \draw (E) edge (F);
   \draw (F) edge (G);
   \draw (F) edge (H);
  \end{tikzpicture}
 }
\end{document}
And blocks the path.
Sample Input 2
6 5
1 2
2 3
3 4
4 6
4 5
1
5
Sample Output 2
4
Explanation for Sample Output 2
Initial setup.
\documentclass {standalone}
\usepackage {tikz}
\usetikzlibrary{positioning,shapes}
\begin {document}
 \resizebox{!}{4cm}{
  \begin {tikzpicture} [node distance=1mm and 8mm, piece/.style={ellipse,minimum width=10mm,draw=black,fill=white}]
   \node[piece] (A) [fill=green] {1};
   \node[piece] (B) [right=of A] {2};
   \node[piece] (C) [right=of B] {3};
   \node[piece] (D) [right=of C] {4};
   \node[piece] (E) [below right=1mm and 10mm of D,fill=orange] {5};
   \node[piece] (F) [above right=1mm and 10mm of D] {6};
   \draw (A) edge (B);
   \draw (B) edge (C);
   \draw (C) edge (D);
   \draw (D) edge (E);
   \draw (D) edge (F);
  \end{tikzpicture}
 }
\end{document}
After 3 turns.
\documentclass {standalone}
\usepackage {tikz}
\usetikzlibrary{positioning,shapes}
\begin {document}
 \resizebox{!}{4cm}{
  \begin {tikzpicture} [node distance=1mm and 8mm, piece/.style={ellipse,minimum width=10mm,draw=black,fill=white}]
   \node[piece] (A) [] {1};
   \node[piece] (B) [right=of A] {2};
   \node[piece] (C) [right=of B] {3};
   \node[piece] (D) [right=of C,fill=green] {4};
   \node[piece] (E) [below right=1mm and 10mm of D,fill=orange] {5};
   \node[piece] (F) [above right=1mm and 10mm of D] {6};
   \draw (A) edge (B);
   \draw (B) edge (C);
   \draw (C) edge (D);
   \draw (D) edge (E);
   \draw (D) edge (F);
  \end{tikzpicture}
 }
\end{document}
However, BMP and MSA's car moves before the ants, narrowly escaping the ants and getting home just before getting eaten.
\documentclass {standalone}
\usepackage {tikz}
\usetikzlibrary{positioning,shapes}
\begin {document}
 \resizebox{!}{4cm}{
  \begin {tikzpicture} [node distance=1mm and 8mm, piece/.style={ellipse,minimum width=10mm,draw=black,fill=white}]
   \node[piece] (A) [] {1};
   \node[piece] (B) [right=of A] {2};
   \node[piece] (C) [right=of B] {3};
   \node[piece] (D) [right=of C,fill=orange] {4};
   \node[piece] (E) [below right=1mm and 10mm of D,fill=orange] {5};
   \node[piece] (F) [above right=1mm and 10mm of D,fill=green] {6};
   \draw (A) edge (B);
   \draw (B) edge (C);
   \draw (C) edge (D);
   \draw (D) edge (E);
   \draw (D) edge (F);
  \end{tikzpicture}
 }
\end{document}
Comments