codeforces#P1766F. MCF
MCF
Description
You are given a graph consisting of $n$ vertices and $m$ directed arcs. The $i$-th arc goes from the vertex $x_i$ to the vertex $y_i$, has capacity $c_i$ and weight $w_i$. No arc goes into the vertex $1$, and no arc goes from the vertex $n$. There are no cycles of negative weight in the graph (it is impossible to travel from any vertex to itself in such a way that the total weight of all arcs you go through is negative).
You have to assign each arc a flow (an integer between $0$ and its capacity, inclusive). For every vertex except $1$ and $n$, the total flow on the arcs going to this vertex must be equal to the total flow on the arcs going from that vertex. Let the flow on the $i$-th arc be $f_i$, then the cost of the flow is equal to $\sum \limits_{i = 1}^{m} f_i w_i$. You have to find a flow which minimizes the cost.
Sounds classical, right? Well, we have some additional constraints on the flow on every edge:
- if $c_i$ is even, $f_i$ must be even;
- if $c_i$ is odd, $f_i$ must be odd.
Can you solve this problem?
The first line contains two integers $n$ and $m$ ($2 \le n \le 100$; $1 \le m \le 200$).
Then $m$ lines follow. The $i$-th of them contains four integers $x_i$, $y_i$, $c_i$, and $w_i$ ($1 \le x_i \le n - 1$; $2 \le y_i \le n$; $x_i \ne y_i$; $1 \le c_i \le 100$; $-100 \le w_i \le 100$). These integers describe the $i$-th arc.
Additional constraints on the input:
- there are no negative cycles in the graph.
If a flow satisfying all of the constraints does not exist, print Impossible.
Otherwise, print two lines:
- the first line should contain one word Possible;
- the second line should contain $m$ integers $f_1, f_2, \dots, f_m$.
If there are multiple answers, print any of them. Note that the cost of the flow should be minimized.
Input
The first line contains two integers $n$ and $m$ ($2 \le n \le 100$; $1 \le m \le 200$).
Then $m$ lines follow. The $i$-th of them contains four integers $x_i$, $y_i$, $c_i$, and $w_i$ ($1 \le x_i \le n - 1$; $2 \le y_i \le n$; $x_i \ne y_i$; $1 \le c_i \le 100$; $-100 \le w_i \le 100$). These integers describe the $i$-th arc.
Additional constraints on the input:
- there are no negative cycles in the graph.
Output
If a flow satisfying all of the constraints does not exist, print Impossible.
Otherwise, print two lines:
- the first line should contain one word Possible;
- the second line should contain $m$ integers $f_1, f_2, \dots, f_m$.
If there are multiple answers, print any of them. Note that the cost of the flow should be minimized.
3 3
1 2 3 -10
1 2 3 -15
2 3 2 0
3 3
1 2 3 -10
1 2 3 -15
2 3 3 0
3 3
1 2 3 -10
1 2 3 -15
2 3 4 0
6 7
5 6 9 -40
1 2 3 -10
1 4 5 20
4 5 7 30
2 5 1 -15
1 3 3 5
3 5 3 0
Possible
1 1 2
Impossible
Possible
1 3 4
Possible
5 1 1 1 1 3 3