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


C++ polygon::get_n方法代码示例

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


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

示例1: earQ

bool earQ(int i, int j, int k, const polygon& p)
{
	triangle t(p.vec_points[i], p.vec_points[k], p.vec_points[k]);
	if (cw(p.vec_points[i], p.vec_points[j], p.vec_points[k]))
		return false;
	
	for (int m = 0; m < p.get_n(); m++) {
		if ((m != i) && (m != j) && (m != k))
			if (t.contains(p.vec_points[m]))
				return false;
	}
	return true;
}
开发者ID:frandibar,项目名称:acm-valladolid,代码行数:13,代码来源:acm.cpp

示例2: t

///////////////////////////////////////////////////////////////////////////
// triangulation implementation
///////////////////////////////////////////////////////////////////////////
triangulation::triangulation(const polygon& p) {
	int n = p.get_n();
	vector<int> vleft(n),	// left neighbor indices
					vright(n);	// rigth neighbor indices
	for (int j = 0; j < n; j++) {
		vleft[j] = ((j-1) + n) % n;
		vright[j] = ((j+1) + n) % n;
	}
	int i = n - 1;
	while ((int)vec_triangles.size() < (n-2)) {
		i = vright[i];
		if (earQ(vleft[i], i, vright[i], p)) {
			triangle t(p.vec_points[vleft[i]], p.vec_points[i], p.vec_points[vright[i]]);
			vec_triangles.push_back(t);
			vleft[vright[i]] = vleft[i];
			vright[vleft[i]] = vright[i];
		}
	}
}
开发者ID:frandibar,项目名称:acm-valladolid,代码行数:22,代码来源:acm.cpp


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