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


C++ graph::new_edge方法代码示例

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


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

示例1: init_handler

void biconnectivity::init_handler(graph& G)
{
	if (add_edges) {
		dfs D;
		D.scan_whole_graph(true);
		D.check(G);
		D.run(G);

		roots_iterator it, end;
		it = D.roots_begin();
		end = D.roots_end();
		start = *(*it);
		++it;

		for (; it != end; ++it) {
			additional.push_back(G.new_edge(start, *(*it)));
		}

		first_child.init(G, node());
	}

	low_num.init(G);
	in_component.init(G);
	cut_count.init(G, 0);

	//
	// Detect self loops and hide them.
	// 

	assert(self_loops.empty());
	graph::edge_iterator eit = G.edges_begin(),
		eend = G.edges_end();

	while (eit != eend) {
		edge e = *eit;
		eit++;
		if (e.target() == e.source()) {
			self_loops.push_back(e);
			G.hide_edge(e);
		}
	}
}
开发者ID:Nuzhny007,项目名称:Multitarget-tracker,代码行数:42,代码来源:biconnectivity.cpp

示例2: after_recursive_call_handler

void biconnectivity::after_recursive_call_handler(graph& G, edge& e, node& n)
{
	node curr = n.opposite(e);

	if (low_num[n] < low_num[curr]) {
		low_num[curr] = low_num[n];
	}

	if (low_num[n] >= dfs_num(curr)) {
		//
		// Component found
		// 

		if (store_comp) {
			component_iterator li = components.insert(
				components.end(),
				std::pair<nodes_t, edges_t>(nodes_t(), edges_t()));

			nodes_t& component = li->first;
			edges_t& co_edges = li->second;

			//
			// Nodes of biconnected component
			// 

			node tmp = node_stack.top();

			while (dfs_num(tmp) >= dfs_num(n)) {
				node_stack.pop();
				component.push_back(tmp);
				in_component[tmp] = li;
				if (node_stack.empty()) break;
				else tmp = node_stack.top();
			}

			component.push_back(curr);

			//
			// edges of biconnected component
			//

			edge ed = edge_stack.top();

			while ((dfs_num(ed.source()) >= dfs_num(n) &&
				dfs_num(ed.target()) >= dfs_num(n)) ||
				(dfs_num(ed.source()) == dfs_num(curr) &&
				dfs_num(ed.target()) >= dfs_num(n)) ||
				(dfs_num(ed.source()) >= dfs_num(n) &&
				dfs_num(ed.target()) == dfs_num(curr))) {
				edge_stack.pop();
				co_edges.push_back(ed);
				if (edge_stack.empty()) break;
				else ed = edge_stack.top();
			}
		}


		++num_of_components;

		//
		// curr is cut point; increase counter
		// 

		++cut_count[curr];

		if (add_edges) {
			node father = (*preds)[curr];
			node first = first_child[curr];

			if (father != node() && n == first) {
				additional.push_back(G.new_edge(father, first));
			}

			if (n != first) {
				additional.push_back(G.new_edge(n, first));
			}
		}

	}
}
开发者ID:Nuzhny007,项目名称:Multitarget-tracker,代码行数:80,代码来源:biconnectivity.cpp


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