在每个节点有多个子节点的树上查找从根到叶的所有可能路由。

时间:2013-07-09 11:10:15

标签: c# depth-first-search

我目前正在开展一个项目,要求我从地下伦敦的一个特定车站找到多条路线。我正在进行的项目是创建路线。我创建了一个使用DFS和递归的方法。 此方法采用起始站的名称,空List和整数值。当我使用以下代码执行该方法时:

GetRoutes("HOLBORN", list, 4);

我在列表中得到以下结果

HOLBORN
CHANCERY LANE
ST PAULS
BANK
LIVERPOOL STREET
TOTTENHAM COURT ROAD
OXFORD CIRCUS
RUSSELL SQUARE
KINGS CROSS
COVENT GARDEN

列表中的第一个字符串显示有效路径:

HOLBORN => CHANCERY LANE => ST PAULS => BANK => LIVERPOOL STREET

然而,我需要再次搜索其他路线,例如:

HOLBORN => CHANCERY LANE => ST PAULS => BANK => LONDON BRIDGE

这是一个值得怀疑的方法:

    public List<string> GetRoutes(string stationName, List<string> completeRoutes, int counter)
    {
        Stack<Node<TrainData>> s = new Stack<Node<TrainData>>();

        s.Push(GetRootStationNode(stationName));

        while (s.Count > 0)
        {
            var currentNode = s.Pop();
            if(!VisitedStation(currentNode.State.StationName, completeRoutes))
            {
                completeRoutes.Add(currentNode.State.StationName);
            }

            var allPossibleStation = GetAllPossibleNextStations(currentNode.State.StationName);

            foreach (var node in allPossibleStation)
            {
                if (counter > 0)
                {
                    if (!node.Visited)
                    {
                        node.Visited = true;
                        s.Push(node);
                        counter--;
                        GetRoutes(node.State.StationName, completeRoutes, counter);
                    }
                }
            }
        }

        return completeRoutes;
    }

以下是检索特定电台的所有子节点的GetAllPossibleNextStations:

  public List<Node<TrainData>> GetAllPossibleNextStations(string input)
    {
        var possibleStations = new List<TrainData>();
        var NodeList = new List<Node<TrainData>>();

        var stationsMatchingInput = from f in dbList
                                    where f.StationName == input
                                    select f;

        foreach (var station in stationsMatchingInput)
        {
            var node = GetNextStation(station.PositionId);
            if (node != null && (node.State.Line == station.Line))
            {
                NodeList.Add(node);
            }
        }

我似乎无法理解这个遍历业务,所以任何建议都会很棒。

0 个答案:

没有答案