РЕДАКТИРОВАТЬ: Использование корня слова в этом посте. не относится к какому-либо зарезервированному термину и представляет собой всего лишь спонтанное имя логической переменной, которая помечает узел как «специальный».
Пока:
Код: Выделить всё
//The node
public class Node
{
public Node[] connectedNodes;
public bool rootNode;
}
//The function
public static bool HasRootNode(Node fromNode)
{
List Processed = new List();
Stack WorkStack = new Stack(FromNode.connectedNodes);
Processed.Add(fromNode);
while (WorkStack.Count != 0)
{
Node workItem = WorkStack.Pop();
foreach (Node cNode in workItem.connectedNodes)
{
if (Processed.Contains(cNode))
continue;
if (cNode.rootNode)
return true; // Found..
WorkStack.Push(cNode); // Queue all of the connectedNodes for this node
Processed.Add(cNode); // This node has been processed..
}
}
return false; // Not found..
}
Подробнее здесь: https://stackoverflow.com/questions/526 ... cific-node
Мобильная версия