## CEOI '19 P4 - Amusement Park

View as PDF

Points: 30 (partial)
Time limit: 1.4s
Memory limit: 1G

Problem types
Allowed languages
Ada, Assembly, Awk, Brain****, C, C#, C++, COBOL, CommonLisp, D, Dart, F#, Forth, Fortran, Go, Groovy, Haskell, Intercal, Java, JS, Kotlin, Lisp, Lua, Nim, ObjC, OCaml, Octave, Pascal, Perl, PHP, Pike, Prolog, Python, Racket, Ruby, Rust, Scala, Scheme, Sed, Swift, TCL, Text, Turing, VB, Zig

You have been hired to supervise the project of a new amusement park. The park will have a special gimmick: directed slides that can get customers from one attraction to another quickly and in an entertaining way.

The park owner has given you the current project: a list of planned attractions and a list of slides that should be built between them. However, him being a businessman, he casually envisioned the impossible: among other things, he projected a slide coming from the Haunted Castle to the Roller Coaster, another from the Roller Coaster to the Drop Tower, and a third from the Drop Tower to the Haunted Castle. As the slides can only go downhill, it is evident why this is a problem. You don't have the luxury of ignoring the laws of physics when building the park, so you have to request changes in the project. Maybe he would accept reversing the slide between the Drop Tower and the Haunted Castle?

Formally:

• The project is a list of attractions and a list of directed slides. Each slide starts at one attraction and ends at another attraction.
• A proposal is obtained from the project by reversing the directions of some slides (possibly none or all of them).
• A proposal is legal if there is a way to assign an elevation to each attraction in such a way that every slide goes downhill.
• The cost of a proposal is the number of slides whose directions were reversed.

For a given project, find and report the sum of costs all legal proposals. Since this number may be large, output it modulo .

#### Input

The first line contains two space-separated integers – the number of attractions and the number of slides, respectively. The attractions are numbered through .

Then, lines follow. The -th of these lines contains two space-separated integers denoting a slide from to .

You may assume that:

• There are no self-loops. (For each : .)
• No slide appears twice. (For all : or .)
• No pair of attractions is connected in both directions. (The unordered pairs are distinct.)

#### Output

Output one line with a single integer, the sum of costs of all legal proposals modulo .

#### Sample Input 1

2 1
1 2

#### Sample Output 1

1

#### Sample Input 2

3 3
1 2
2 3
1 3

#### Sample Output 2

9

#### Note

In the first example, there are two proposals:

• The slide direction is not flipped. This proposal has cost .
• The slide direction is flipped. This proposal has cost .

As both proposals are valid, the answer is .

In the second example, there are eight proposals with the slide directions as follows:

• (cost )
• (cost )
• (cost )
• (cost )
• (cost )
• (cost )
• (cost )
• (cost )

The second proposal is not legal, as there is a slide sequence . This means that the attraction has to be strictly higher than itself, which is clearly impossible. Similarly, the seventh proposal is not legal. The answer is thus .