##[$AcWing$ $1123$](https://www.acwing.com/problem/content/1125/)
### 一、题目描述
随着白天越来越短夜晚越来越长,我们不得不考虑铲雪问题了。
整个城市所有的道路都是双向车道,道路的两个方向均需要铲雪。因为城市预算的削减,整个城市只有 $1$ 辆铲雪车。
铲雪车只能把它开过的地方(车道)的雪铲干净,无论哪儿有雪,铲雪车都得从停放的地方出发,**游历整个城市** 的街道。
现在的问题是:**最少要花多少时间去铲掉所有道路上的雪呢**?
**输入格式**
输入数据的第 $1$ 行表示铲雪车的停放坐标 $(x,y)$,$x,y$ 为整数,单位为米。
下面最多有$4000$行,每行给出了一条街道的起点坐标和终点坐标,坐标均为整数,所有街道都是笔直的,且都是 **双向车道**。
铲雪车可以在任意交叉口、或任何街道的末尾任意转向,包括转 $U$ 型弯。
铲雪车铲雪时前进速度为 $20$ 千米/时,不铲雪时前进速度为 $50$ 千米/时。
保证:铲雪车从起点一定可以到达任何街道。
**输出格式**
输出铲掉所有街道上的雪并且返回出发点的最短时间,精确到分钟,四舍五入到整数。
输出格式为`hours:minutes`,$minutes$不足两位数时**需要补前导零**。
具体格式参照样例。
**数据范围**
$−10^6≤x,y≤10^6$
所有位置坐标绝对值不超过 $10^6$。
**输入样例**:
```cpp {.line-numbers}
0 0
0 0 10000 10000
5000 -10000 5000 10000
5000 10000 10000 10000
```
**输出样例**:
```cpp {.line-numbers}
3:55
```
**样例解释**
输出结果表示共需$3$小时$55$分钟。
### 二、[前导知识](https://www.cnblogs.com/littlehb/p/15129083.html)
#### 欧拉路径
图中所有的边都经过且只经过一次(一笔画)
#### 欧拉回路
起点与终点相同的欧拉路径
| 类型 | 存在欧拉路径 | 存在欧拉回路 | 总结 |
| ---------- | --------------------------------------------------------------------------------------------------------------------------------- | ------------------------- | -------------------- |
| **无向图** | 度数为奇数的点只能有$0$或$2$个 | 度数为奇数的点只能有$0$个 | 度数是奇数的点有几个 |
| **有向图** | ① 所有点的出度均等于入度
② 除两个点外,其余点出度等于入度, 此两点:一个出度比入度多$1$(起点),另一个入度比出度多$1$(终点) | 所有点的出度均等于入度 | 出度与入度是不是相等 |
### 三、题目解析
这是个智力题。
这个图很特殊,每个点的入度和出度是一样的。这是一个欧拉图。
所以我们只要把每条路的长度算出来,除以速度就行了。
答案和铲雪车一开始在哪里无关。
**注意**
$50km/h$的速度在本题中没有任何作用,图不需要建出
### $Code$
```cpp {.line-numbers}
#include
using namespace std;
int main() {
double x1, y1, x2, y2;
cin >> x1 >> y1;
double sum = 0;
while (cin >> x1 >> y1 >> x2 >> y2) {
double dx = x1 - x2;
double dy = y1 - y2;
//欧几里得距离
sum += sqrt(dx * dx + dy * dy) * 2;
// sum += hypot(dx, dy) * 2;
}
// 20千米/小时
int minutes = round(sum / 1000 / 20 * 60);
int hours = minutes / 60;
minutes %= 60;
printf("%d:%02d\n", hours, minutes);
return 0;
}
```