zoukankan      html  css  js  c++  java
  • BFS

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    
    namespace BFS
    {
        class Program
        {
            private const int MAXX = 100;
            private const int MAXY = 100;
    
            private static int m_dx = -1;
            private static int m_dy = -1;
    
            private static Queue<Point> m_Q; 
    
            static void Main(string[] args)
            {
                int xlength = 4;
                int ylength = 4;
                Point[][] g = new Point[xlength][];
                int[][] map = new int[][]
                    {new int[] {0, 0, 0, 0}, new int[] {0, 1, 0, 1}, new int[] {0, 0, 0, 1}, new int[] {1, 2, 1, 1}};
    
                Inist(g, xlength, ylength);
                BFS(g, new Point() {X = 0, Y = 0}, xlength, ylength, map);
                var end = g[m_dx][m_dy].Distance;
            }
            public static void Inist(Point[][] g,int xlength,int ylenth)
            {
                for (int i = 0; i <xlength; i++)
                {
                    g[i] = new Point[ylenth];
                }
                m_Q = new Queue<Point>();
            }
            public static void BFS(Point[][] g, Point s, int xlength, int ylength,int[][] map)
            {
                for (int i = 0; i < xlength; i++)
                {
                    for (int j = 0; j < ylength; j++)
                    {
                        var type = map[i][j];
                        g[i][j] = new Point() { Color = 0, Distance = int.MaxValue, Parent = null, X = i, Y = j, type = type };
                        if(type==2)
                        {
                            m_dx = i;
                            m_dy = j;
                            g[i][j].type = 0;
                        }
                    }
                }
                g[s.X][s.Y].Color = 1;
                g[s.X][s.Y].Distance = 0;
                g[s.X][s.Y].Parent = null;
    
                m_Q.Enqueue(g[s.X][s.Y]);
                while (m_Q.Count!=0)
                {
                    Point u = m_Q.Dequeue();
                    var adjList = GenerAdjustList(g, u, xlength,ylength);
                    for (int i = 0; i < adjList.Count; i++)
                    {
                        var v = adjList[i];
                        if(v.Color==0&&v.type==0)
                        {
                            v.Color = 1;
                            v.Distance = u.Distance + 1;
                            v.Parent = u;
                            m_Q.Enqueue(v);
                        }
                    }
                    u.Color = 2;
                }
            }
    
            private static List<Point> GenerAdjustList(Point[][] points, Point point, int xlength, int ylength)
            {
                var list = new List<Point>();
                if(point.X+1<xlength)
                {
                    list.Add(points[point.X+1][point.Y]);
                }
                if(point.X-1>0)
                {
                    list.Add(points[point.X - 1][point.Y]);
                }
                if (point.Y + 1 < ylength)
                {
                    list.Add(points[point.X][point.Y + 1]);
                }
                if (point.Y - 1 > 0)
                {
                    list.Add(points[point.X][point.Y - 1]);
                }
                return list;
            }
    
        }
        public class Point
        {
            public int X;
            public int Y;
    
            public int Color;
    
            public int type;
    
            public int Distance;
    
            public Point Parent;
        }
    }
  • 相关阅读:
    开源搜索引擎Solr的快速搭建及集成到企业门户最佳实施方案--转载
    Java开发WebService的几种方法--转载
    HBase Java简单示例--转载
    Eclipse快捷键大全--转载
    Java中List、Set和Map的区别--转载
    ArrayList和Iterator的用法
    日期格式化
    java中的值传递和引用传递问题
    Servlet,过滤器,监听器,拦截器的区别
    Java过滤器与SpringMVC拦截器之间的关系与区别
  • 原文地址:https://www.cnblogs.com/suriyel/p/2930969.html
Copyright © 2011-2022 走看看