本文整理汇总了C++中Visitor::IsDone方法的典型用法代码示例。如果您正苦于以下问题:C++ Visitor::IsDone方法的具体用法?C++ Visitor::IsDone怎么用?C++ Visitor::IsDone使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Visitor
的用法示例。
在下文中一共展示了Visitor::IsDone方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Accept
void ListAsArray::Accept(Visitor& visitor) const
{
for(unsigned int i = 0; i < nCount && !visitor.IsDone(); i++)
{
visitor.Visit(*(array[i]));
}
}
示例2: Accept
void StackAsArray::Accept (Visitor& visitor) const
{
for (unsigned int i = 0; i < count && !visitor.IsDone (); ++i)
{
visitor.Visit (*array [i]);
}
}
示例3: TopologicalOrderTraversal
//
// This file contains the C++ code from Program 16.9 of
// "Data Structures and Algorithms
// with Object-Oriented Design Patterns in C++"
// by Bruno R. Preiss.
//
// Copyright (c) 1998 by Bruno R. Preiss, P.Eng. All rights reserved.
//
// http://www.pads.uwaterloo.ca/Bruno.Preiss/books/opus4/programs/pgm16_09.cpp
//
void Digraph::TopologicalOrderTraversal (Visitor& visitor) const
{
Array<unsigned int> inDegree (numberOfVertices);
for (Vertex::Number v = 0; v < numberOfVertices; ++v)
inDegree [v] = 0;
Iterator& p = Edges ();
while (!p.IsDone ()) {
Edge& edge = dynamic_cast<Edge&> (*p);
++inDegree [edge.V1 ()];
++p;
}
delete &p;
Queue& queue = *new QueueAsLinkedList ();
queue.RescindOwnership ();
for (Vertex::Number v = 0; v < numberOfVertices; ++v)
if (inDegree [v] == 0)
queue.Enqueue (SelectVertex (v));
while (!queue.IsEmpty () && !visitor.IsDone ())
{
Vertex& vertex =
dynamic_cast<Vertex&> (queue.Dequeue ());
visitor.Visit (vertex);
Iterator& q = EmanatingEdges (vertex);
while (!q.IsDone ()) {
Edge& edge = dynamic_cast<Edge&> (*q);
Vertex& to = edge.V1 ();
if (--inDegree [to] == 0)
queue.Enqueue (to);
++q;
}
delete &q;
}
delete &queue;
}
示例4: Accept
void BagAsLinkedList::Accept (Visitor& visitor) const
{
ListElement<Object*> const* ptr;
for (ptr = list.Head (); ptr != 0 && !visitor.IsDone (); ptr = ptr->Next())
{
visitor.Visit (*ptr->Datum ());
}
}
示例5: BreadthFirstTraversal
void Tree::BreadthFirstTraversal (Visitor& visitor) const
{
Queue& queue = *new QueueAsLinkedList ();
queue.RescindOwnership ();
if (!IsEmpty ())
queue.Enqueue (const_cast<Tree&> (*this));
while (!queue.IsEmpty () && !visitor.IsDone ())
{
Tree const& head = dynamic_cast<Tree const &> (queue.Dequeue ());
visitor.Visit (head.Key ());
for (unsigned int i = 0; i < head.Degree (); ++i)
{
Tree& child = head.Subtree (i);
if (!child.IsEmpty ())
queue.Enqueue (child);
}
}
delete &queue;
}