当前位置: 首页>>代码示例>>C++>>正文


C++ Grafo::busca方法代码示例

本文整理汇总了C++中Grafo::busca方法的典型用法代码示例。如果您正苦于以下问题:C++ Grafo::busca方法的具体用法?C++ Grafo::busca怎么用?C++ Grafo::busca使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Grafo的用法示例。


在下文中一共展示了Grafo::busca方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: main

int main()
{
	Grafo *G = new Grafo();
	queue<Vertice*> FilaVertices;
	Vertice *v;
	register unsigned int i, j;
	
	G->leGrafo();
	
	// busca por vértices não visitados
	while ( ( v = G->busca( false ) ) != NULL )
	{
		// enfila v
		FilaVertices.push( v );

		while ( ! FilaVertices.empty() )
		{
			v = FilaVertices.front();
			FilaVertices.pop();

			// exibe visita ao vértice
			v->exibir();
			cout << " ";

			v->setVisitado( true );

			list<Vertice*> vizinhos = G->buscaVizinhos( G, *v );

			if ( vizinhos.size() > 0 )
			{
				while ( ! vizinhos.empty() )
				{
					Vertice *w = vizinhos.front();

					vizinhos.pop_front();

					if ( ! w->isVisitado() )
					{
						w->setVisitado( true );
						FilaVertices.push( w );
						/*
						 * As duas linahs abaixo foram adicinoadas a fim de corrigir a primeira versão
						 * do trabalho. Mais informações no comentário da linha 117 do arquivo lib/grafo.cpp
						*/
						G->matrizAdjacencia[ v->getNome() ][ w->getNome() ].setTipoArvore( true );
						G->matrizAdjacencia[ w->getNome() ][ v->getNome() ].setTipoArvore( true );
					}
				}
			}
		}
	}

	cout << endl;

	for ( i = 1; i <= G->getNumVertices(); i++ )
	{
		for ( j = 1; j < i; j++ )
		{
			if ( G->matrizAdjacencia[i][j].isAresta() )
			{
				if ( G->matrizAdjacencia[i][j].isTipoArvore() )
				{
					cout << CHAR_ARVORE;
				}
				else
				{
					cout << CHAR_NAOARVORE;
				}

				cout << " " << i << " " << j << endl;
			}
		}
	}

	return 0;
}
开发者ID:HenriqueVarellaEhrenfried,项目名称:anotacoes-ufpr-1,代码行数:76,代码来源:bfs.cpp


注:本文中的Grafo::busca方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。