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


C++ CArray::FindMax方法代码示例

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


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

示例1: GetPave

int CoreScript::GetPave()
{
	if (pave) {
		return pave;
	}

	// OLD: Pavement is used as a flag for "this is a road" by the AI.
	// It's important to use the least common pave in a domain
	// so that building isn't interfered with.
	// NOW: Just use least common pave to spread things out.
	CArray<int, WorldGrid::NUM_PAVE> nPave;
	for (int i = 0; i < WorldGrid::NUM_PAVE; ++i) nPave.Push(0);

	if (pave == 0) {
		Rectangle2I inner = InnerSectorBounds(ToSector(parentChit->Position()));
		for (Rectangle2IIterator it(inner); !it.Done(); it.Next()) {
			const WorldGrid& wg = Context()->worldMap->GetWorldGrid(it.Pos());
			nPave[wg.Pave()] += 1;
		}
	}

	nPave[0] = 0;
	int maxPave = nPave[nPave.FindMax(0, [](int, int count) { return count; })];

	if (maxPave == 0) {
		pave = 1 + parentChit->random.Rand(WorldGrid::NUM_PAVE - 1);
	}
	else {
		pave = 1 + ArrayFindMax(nPave.Mem()+1, nPave.Size() - 1, 0, [](int, int count) { return -count; });
	}
	GLASSERT(pave > 0 && pave < nPave.Size());
	if (pave == 0) {
		pave = 1;
	}
	return pave;
}
开发者ID:csioza,项目名称:alteraorbis,代码行数:36,代码来源:corescript.cpp


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