Exemplo n.º 1
0
        public static (double[, ], string[, ]) FindShortestPathMatrix(AdjacencyList list)
        {
            _list = list;

            D = _list.GetAdjacencyMatrix();

            F = new string[_list.Length, _list.Length];

            for (int i = 0; i < _list.Length; i++)
            {
                for (int j = 0; j < _list.Length; j++)
                {
                    F[i, j] = _list[j];
                }
            }

            for (int k = 0; k < _list.Length; ++k)
            {
                for (int i = 0; i < _list.Length; ++i)
                {
                    for (int j = 0; j < _list.Length; ++j)
                    {
                        if (D[i, k] + D[k, j] < D[i, j])
                        {
                            D[i, j] = D[i, k] + D[k, j];

                            F[i, j] = F[i, k] + "-> " + F[k, j];
                        }
                    }
                }
            }

            return(D, F);
        }
Exemplo n.º 2
0
        static void Main(string[] args)
        {
            AdjacencyList list = FileHandler.CreateAdjacencyList(@"..\..\..\Cities.txt");

            Console.WriteLine("Матрица смежности:");

            for (int i = 0; i < list.GetAdjacencyMatrix().GetLength(0); i++)
            {
                for (int j = 0; j < list.GetAdjacencyMatrix().GetLength(1); j++)
                {
                    Console.Write($"{list.GetAdjacencyMatrix()[i,j]} ");
                }
                Console.WriteLine();
            }
            Console.WriteLine();

            AlgorithmFloyd.FindShortestPathMatrix(list);

            Console.WriteLine("Матрица кратчайших путей:");
            AlgorithmFloyd.PrintShortestPathMatrix();
        }