Data Center Drama
题意翻译
- 给定一张 $n$ 个点 $m$ 条边的连通无向图。
- 你需要加尽可能少的边,然后给所有边定向,使得每一个点的出入度都是偶数。
- 边可以是自环,也可以有重边。
- $n \le 10^5$,$m \le 2 \times 10^5$。
题目描述
The project of a data center of a Big Software Company consists of $ n $ computers connected by $ m $ cables. Simply speaking, each computer can be considered as a box with multiple cables going out of the box. Very Important Information is transmitted along each cable in one of the two directions. As the data center plan is not yet approved, it wasn't determined yet in which direction information will go along each cable. The cables are put so that each computer is connected with each one, perhaps through some other computers.
The person in charge of the cleaning the data center will be Claudia Ivanova, the janitor. She loves to tie cables into bundles using cable ties. For some reasons, she groups the cables sticking out of a computer into groups of two, and if it isn't possible, then she gets furious and attacks the computer with the water from the bucket.
It should also be noted that due to the specific physical characteristics of the Very Important Information, it is strictly forbidden to connect in one bundle two cables where information flows in different directions.
The management of the data center wants to determine how to send information along each cable so that Claudia Ivanova is able to group all the cables coming out of each computer into groups of two, observing the condition above. Since it may not be possible with the existing connections plan, you are allowed to add the minimum possible number of cables to the scheme, and then you need to determine the direction of the information flow for each cable (yes, sometimes data centers are designed based on the janitors' convenience...)
输入输出格式
输入格式
The first line contains two numbers, $ n $ and $ m $ ( $ 1<=n<=100000 $ , $ 1<=m<=200000 $ ) — the number of computers and the number of the already present cables, respectively.
Each of the next lines contains two numbers $ a_{i},b_{i} $ ( $ 1<=a_{i},b_{i}<=n $ ) — the indices of the computers connected by the $ i $ -th cable. The data centers often have a very complex structure, so a pair of computers may have more than one pair of cables between them and some cables may connect a computer with itself.
输出格式
In the first line print a single number $ p $ ( $ p>=m $ ) — the minimum number of cables in the final scheme.
In each of the next $ p $ lines print a pair of numbers $ c_{i},d_{i} $ ( $ 1<=c_{i},d_{i}<=n $ ), describing another cable. Such entry means that information will go along a certain cable in direction from $ c_{i} $ to $ d_{i} $ .
Among the cables you printed there should be all the cables presented in the original plan in some of two possible directions. It is guaranteed that there is a solution where $ p $ doesn't exceed $ 500000 $ .
If there are several posible solutions with minimum possible value of $ p $ , print any of them.
输入输出样例
输入样例 #1
4 6
1 2
2 3
3 4
4 1
1 3
1 3
输出样例 #1
6
1 2
3 4
1 4
3 2
1 3
1 3
输入样例 #2
3 4
1 2
2 3
1 1
3 3
输出样例 #2
6
2 1
2 3
1 1
3 3
3 1
1 1
说明
Picture for the first sample test. The tied pairs of cables are shown going out from the same point.
![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF527E/4abda3017c500d7e7862903d06b135eb9ad26230.png)Picture for the second test from the statement. The added cables are drawin in bold.
![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF527E/01fdb0d798b75335f4d207095e9844e2c00bee6c.png)Alternative answer for the second sample test:
![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF527E/1fee03d352ebeccd4924ce3e2bd284be7d51be5e.png)