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


C++ Genome::add_gene方法代码示例

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


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

示例1: time

Genome*
AverageCombinator::combine(Genome *x, Genome *y) {
	srand ( time(NULL) );

	int size = x->get_size( );
	Genome *z = new Genome();

	double chanceFactor = 0.5;
	for(int i = 0; i < size; i++) {
		double chance = (((double) rand()) / RAND_MAX+1);
		if(chance < chanceFactor) {
			double totalTime = x->get_gene(i)->getTime().getTimeInMinutes() + y->get_gene(i)->getTime().getTimeInMinutes();

			Time t;
			t.addMinute(floor((totalTime / 2) + 0.5));
			z->add_gene(x->get_gene(i)->getPlane(), t);
		} else if(chance < 0.75) {
			z->add_gene( x->get_gene(i)->getPlane(), x->get_gene(i)->getTime());
		} else {
			z->add_gene( y->get_gene(i)->getPlane(), y->get_gene(i)->getTime());
		}
	}

	return z;
}
开发者ID:misthafalls,项目名称:AirportScheduling,代码行数:25,代码来源:Combinator.cpp

示例2: Genome

Genome* 
SimpleCombinator::combine(Genome *x, Genome *y) {
	int size = x->get_size( );
	Genome *z = new Genome();

	for(int i = 0; i < size; i++) {
		if(i % 2 == 0) {
			//add gene from x to z at index i
			z->add_gene( x->get_gene(i)->getPlane(), x->get_gene(i)->getTime());
		} else {
			//add gene from y to z at index i
			z->add_gene( y->get_gene(i)->getPlane(), y->get_gene(i)->getTime());
		}
	}

	return z;
}
开发者ID:misthafalls,项目名称:AirportScheduling,代码行数:17,代码来源:Combinator.cpp


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