示例#1
0
        public void Analize(int de, int para)
        {
            Noh resultado;

            try
            {
                resultado = CalculaCaminho(de, para);
            }
            catch (Exception e)
            {
                Console.WriteLine($"{_nomes[de]} nao esta conectado a {_nomes[de]}");
                return;
            }

            Console.WriteLine($"{_nomes[FIRST_VERTEX]} ->");

            for (Noh temp = resultado; temp.proximo != null; temp = temp.proximo)
            {
                Console.WriteLine($"{_nomes[temp.nohAtual]} - {temp.distancia}");
                dist += temp.distancia;
            }

            int distanciaFinal = resultado.distancia;

            Console.WriteLine($"-> {_nomes[FIRST_VERTEX]}");
            Console.WriteLine($"Distancia: {dist}");
            Console.WriteLine($"Comparacoes: {comparacoes}");
        }
示例#2
0
        private Noh CalculaCaminho(int src, int dest)
        {
            if (src == dest)
            {
                return(new Noh(dest, 0, null));
            }
            ArrayList sucessores = new ArrayList();

            for (int z = FIRST_VERTEX; z <= LAST_VERTEX; z++)
            {
                if ((sucessor(src, z)) && (!stack.Contains(z)))

                {
                    sucessores.Add(z);
                }
            }
            stack.Push(src);
            Noh NohDoSucessor = null;

            foreach (int _sucessor in sucessores)
            {
                try
                {
                    Noh to = CalculaCaminho(_sucessor, dest);
                    int DistanciaDoSucessor = _distancias[src, _sucessor];
                    if ((NohDoSucessor == null) || (NohDoSucessor.distancia == INF) || (DistanciaDoSucessor < NohDoSucessor.distancia))
                    {
                        NohDoSucessor = new Noh(_sucessor, DistanciaDoSucessor, to);
                    }
                    comparacoes++;
                }
                catch (Exception e)
                {
                    continue;
                }
            }
            stack.Pop();
            if (NohDoSucessor == null)
            {
                return(null);
                // throw new Exception();
            }
            return(NohDoSucessor);
        }
示例#3
0
 public Noh(int currentNoh, int dist, Noh next)
 {
     this.nohAtual  = currentNoh;
     this.distancia = dist;
     this.proximo   = next;
 }