本文整理汇总了C++中TNode::RandomPosition方法的典型用法代码示例。如果您正苦于以下问题:C++ TNode::RandomPosition方法的具体用法?C++ TNode::RandomPosition怎么用?C++ TNode::RandomPosition使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TNode
的用法示例。
在下文中一共展示了TNode::RandomPosition方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1:
TMaze::TMaze(int ANumerOfNodes, int ANumberOfLinks)
{
NumberOfNodes = ANumerOfNodes;
NumberOfLinks = ANumberOfLinks;
if(!CheckCorrectessOfKand())
{
std::cout<<"Error!";
return ;
}
Nodes = new TNode[NumberOfNodes];
Links = new TLink[NumberOfLinks];
TNode *oNode;
bool bSucces = false;
for(int iK = 0; iK < NumberOfNodes; iK++)
{
oNode = new TNode;
while(!bSucces)
{
bSucces = true;
oNode->RandomPosition();
for(int iI = 0; iI < iK; iI++)
{
if(NodeAreEquals(*oNode, Nodes[iI]))
{
bSucces = false;
break;
}
}
}
Nodes[iK] = *oNode;
}
for(int iK = 0; iK < NumberOfLinks; iK++)
{
bool BSucces = false;
TNode oNode1, oNode2;
TLink *oLink;
while(!BSucces)
{
oLink = new TLink;
BSucces = true;
oNode1 = Nodes[rand() % NumberOfNodes];
oNode2 = Nodes[rand() % NumberOfNodes];
if(NodeAreEquals(oNode1, oNode2))
{
BSucces = false;
}
if(BSucces)
{
Links[iK] = *oLink;
for(int iI = 0; iI < iK; iI++)
{
TLink oLinkTemp = Links[iI];
if(!LinksAreEquals(*oLink, oLinkTemp))
{
BSucces = false;
}
}
}
}
Links[iK] = *oLink;
}
}