1477: CF91 - C. Ski Base
[Creator : ]
Description
A ski base is planned to be built in Walrusland. Recently, however, the project is still in the constructing phase. A large land lot was chosen for the construction. It contains $n$ ski junctions, numbered from $1$ to $n$. Initially the junctions aren't connected in any way.
In the constructing process $m$ bidirectional ski roads will be built. The roads are built one after another: first the road number $1$ will be built, then the road number $2$, and so on. The $i$-th road connects the junctions with numbers $a_i$ and $b_i$.
Track is the route with the following properties:
Two ski bases are considered different if they consist of different road sets.
After building each new road the Walrusland government wants to know the number of variants of choosing a ski base based on some subset of the already built roads. The government asks you to help them solve the given problem.
Track is the route with the following properties:
- The route is closed, that is, it begins and ends in one and the same junction.
- The route contains at least one road.
- The route doesn't go on one road more than once, however it can visit any junction any number of times.
Two ski bases are considered different if they consist of different road sets.
After building each new road the Walrusland government wants to know the number of variants of choosing a ski base based on some subset of the already built roads. The government asks you to help them solve the given problem.
Input
The first line contains two integers $n,m\ (2≤n≤10^5,\ 1≤m≤10^5)$. They represent the number of junctions and the number of roads correspondingly.
Then on $m$ lines follows the description of the roads in the order in which they were built. Each road is described by a pair of integers $a_i,b_i\ (1≤a_i,b_i≤n,\ a_i≠b_i)$ − the numbers of the connected junctions. There could be more than one road between a pair of junctions.
Then on $m$ lines follows the desc
Output
Print $m$ lines: the $i$-th line should represent the number of ways to build a ski base after the end of construction of the road number $i$. The numbers should be printed modulo $10^9+9$.
Sample 1 Input
3 4
1 3
2 3
1 2
1 2
Sample 1 Output
0
0
1
3
Let us have 3 junctions and 4 roads between the junctions have already been built (as after building all the roads in the sample): 1 and 3, 2 and 3, 2 roads between junctions 1 and 2. The land lot for the construction will look like this:
The land lot for the construction will look in the following way:
We can choose a subset of roads in three ways:
In the first and the second ways you can choose one path, for example, 1 - 2 - 3 - 1. In the first case you can choose one path 1 - 2 - 1.