用递归找到最便宜的路

时间:2019-02-15 11:23:00

标签: c# algorithm recursion

我需要使用递归找到最便宜的道路。
这条道路始于第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循环的建议如何?

2 个答案:

答案 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];
                        }

                    }

                }
            }

        }