中国邮递员问题
一个邮递员送信,要走完他负责投递的全部街道(所有街道都是双向通行的且每条街道可以经过不止一次),完成任务后回到邮局,应按怎样的路线走,他所走的路程才会最短呢?
解决方案
1、图论建模
由于街道是双向通行的,我们可以把它看成是赋权无向连通图,将路口模型为点,街道模型为边,街道的长度就是每条边的权值,问题转化为在图中求一条回路,使得回路的总权值最小。
1.1最理想的情况
若图中有欧拉回路,因为欧拉回路通过所有的边,因此任何一个欧拉回路即为此问题的解。
1.2若G只有两个奇点Vi,Vj
则有从Vi到Vj的欧拉迹,从Vj回到Vi则必须重复一些边,使重复边的总长度最小,转化为求从Vi到Vj的最短路径。算法:
1) 找出奇点Vi,Vj之间的最短路径P;
2) 令G’ = G + P;
3) G’