Exemplo n.º 1
0
        static void Main(string[] args)
        {
            var board = new Board("../../Maze.txt");
            var agent = new Wanderer(ref board, new Point(1, 1));

            //Stopwatch watch = Stopwatch.StartNew();
            Solve(agent, board, null);
            if (!board.Edge(agent.CurrentPosition.X, agent.CurrentPosition.Y))
            {
                Console.WriteLine("[X] Unable to find a solution.");
            }
            else
            {
                Console.WriteLine("\n[V] Travel map: \n" + board.Print());
                Console.WriteLine("\nTravel rules: " + agent.PrintTravelRules());
                Console.WriteLine("\nTravel points: " + agent.PrintTravelPoints());
            }
            Console.ReadKey();
        }
Exemplo n.º 2
0
        static void Solve(Wanderer agent, Board board, Stopwatch watch)
        {
            if (board.Edge(agent.CurrentPosition.X, agent.CurrentPosition.Y))
            {
                return;
            }

            //// Benchmarking
            //if (watch.IsRunning && knight.MoveLog.Count > 100000)
            //{
            //    watch.Stop();
            //    Console.WriteLine("100000 moves took: " + (watch.ElapsedMilliseconds).ToString());
            //    Console.ReadKey();
            //}

            //// Board printing
            //string boardView = board.Print();
            //Console.WriteLine(boardView);

            Dictionary <int, Point> goodDestinations = agent.GoodDestinations(board);

            while (goodDestinations.Count > 0)
            {
                // Manual Pop of the next destination
                var nextDestination = goodDestinations.First();
                goodDestinations.Remove(nextDestination.Key);

                agent.MoveTo(board, nextDestination.Value, nextDestination.Key);

                Solve(agent, board, watch);
                if (board.Edge(agent.CurrentPosition.X, agent.CurrentPosition.Y))
                {
                    return;
                }
            }
            if (!board.Edge(agent.CurrentPosition.X, agent.CurrentPosition.Y))
            {
                agent.Backtrack(board);
            }
            return;
        }