巡回旅行商問題(Traveling Salesman Problem,TSP),也稱為貨郎擔問題。該問題可簡單描述為走遍n個城市的最短路。幾十年來,出現了很多近似優化算法。如近鄰法、貪心算法、最近插入法、最遠插入法、模擬退火算法以及遺傳算法。
問題1 設有一個售貨員從10個城市中的某一個城市的出發,去其他9個城市推銷產品。10個城市的距離已經給出。10個城市相互距離如下表。要求每個城市到達一次僅以此后,回到原出發城市。問:他如何選擇旅行路線,使總路程最短。



model:
sets:
city/1..10/:u;
link(city,city):d,x;
endsets
data:
d=0 7 4 5 8 6 12 13 11 18
7 0 3 10 9 14 5 14 17 17
4 3 0 5 9 10 21 8 27 12
5 10 5 0 14 9 10 9 23 16
8 9 9 14 0 7 8 7 20 19
6 14 10 9 7 0 13 5 25 13
12 5 21 10 8 13 0 23 21 18
13 14 8 9 7 5 23 0 18 12
11 17 27 23 20 25 21 18 0 16
18 17 12 16 19 13 18 12 16 0;
@text()=@writefor(link(i,j)|x(i,j)#GT#0:'x(',i,',',j,')=',x(i,j));
enddata
min=@sum(link:d*x);
@for(city(j):@sum(city(i)|j#ne#i:x(i,j))=1);
@for(city(i):@sum(city(j)|j#ne#i:x(i,j))=1);
@for(link(i,j)|i#ne#j#and#i#gt#1:u(i)-u(j)+10*x(i,j)<=9);
@for(link:@BIN(x));
end
x(1,4)=1 x(2,7)=1 x(3,2)=1 x(4,3)=1 x(5,6)=1 x(6,8)=1 x(7,5)=1 x(8,10)=1 x(9,1)=1 x(10,9)=1
1 4 3 2 7 5 6 8 10 9 1
