我需要使用递归找到最便宜的道路。
这条道路始于第1点,它需要经过所有其他点(2,3,4,5)再回到第1点。每个点之间的旅行费用在二维数组(地图)中。
╔═══════════════════════╗
║ 1|2|3|4|5|(points) ║
║ 1--0 1 3 4 2 ║
║ 2--1 0 4 2 6 ║
║ 3--3 4 0 7 1 ║
║ 4--4 2 7 0 7 ║
║ 5--2 6 1 7 0 ║
║ (points) ║
╚═══════════════════════╝
这意味着从点1到点5的成本为2,从点5到点4的成本为7。每次在地图中切换“方向”时。我认为尝试次数应等于25(4!+ 1)
void FindingRoad(int[][] map, int[] pointsOrder, ref int tripCost, ref int attempts)
{
if (attempts == 0)
{
return;
}
int tempCost = 0;
int[] tempPointsOrder = new int[5];
for (int i = 0; i < 5; i++)
{
for (int j = 0; j < 5; j++)
{
}
}
if (tempCost<tripCost)
{
tripCost = tempCost;
pointsOrder = tempPointsOrder;
}
attempts--;
FindingRoad(map,pointsOrder,ref tripCost,attempts);
}
预期的道路(点数)输出应为1、5(2),3(1),2(4),4(2),1(4),且成本= 13
关于for
循环的建议如何?
答案 0 :(得分:2)
Travelling Saleman Problem是一个优化问题,已知为NP-hard,这意味着不太可能接受有效的最佳算法。话虽如此,有可能使用Dynamic Programming在指数运行时范围内解决它。可以在here或(在最近的出版物中)here中找到这种算法。
答案 1 :(得分:1)
有3个主要功能。第一条和第二条创建所有可能的道路,第三条计算其成本。希望对您有所帮助
static void AllRoads(int[] a, int size, int n, RoadContainer VisiKeliai, int[][]map)
{
// if size becomes 1 then prints the obtained
// permutation
if (size == 1)
printArr(a, n, VisiKeliai,map);
for (int i = 0; i < size; i++)
{
AllRoads(a, size - 1, n, VisiKeliai,map);
// if size is odd, swap first and last
// element
if (size % 2 == 1)
{
int temp = a[0];
a[0] = a[size - 1];
a[size - 1] = temp;
}
// If size is even, swap ith and last
// element
else
{
int temp = a[i];
a[i] = a[size - 1];
a[size - 1] = temp;
}
}
}
static void printArr(int[] a, int n, RoadContainer VisiKeliai, int[][]map)
{
string s = "0";
// Console.WriteLine("dassaddsasdaasdas" + a.Length);
for (int i = 0; i < n; i++)
{
// Console.Write(a[i] + " ");
s += Convert.ToString(a[i]);
}
s = s.Insert(s.Length, "0");
Road r = new Road(s);
CalculatingPrice(r, map);
VisiKeliai.AddRoad(r);
//Console.WriteLine(s);
}
public static void CalculatingPrice(Road Kelias, int[][] map)
{
// 021430 Road im checking
Console.WriteLine("Kelias: " + Kelias.Path);
for (int i = 0; i < Kelias.Path.Length - 1; i++)
{
int nextI = i + 1;
for (int j = 0; j < 5; j++)
{
for (int m = 0; m < 5; m++)
{
string a = Convert.ToString(m);
string aaa = Convert.ToString(Kelias.Path[i]);
string b = Convert.ToString(j);
string bbb = Convert.ToString(Kelias.Path[nextI]);
if (a == aaa && b == bbb)
{
Console.WriteLine(a + "--" + aaa + "---" + b + "----" + bbb + "-------------" + map[j][m]);
Kelias.Cost += map[j][m];
}
}
}
}
}