亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cgaqueen.cpp

?? 自己收集的八皇后問題相關知識,有不少源代碼,能解決八皇后問題
?? CPP
字號:
#include "CgaQueen.h"

CgaQueen::CgaQueens(double CrossRate,double MutationRate,int ChromoLength,int PopSize)
{
	m_dCrossRate = CrossRate;

	m_dMutationRate = MutationRate;

	m_iChromoLength = ChromoLength;

	m_iPopSize = PopSize;

	m_dTotalFitnessScore = 0.0;

	m_dBestFitnessScore = 1.0;

	m_iGeneration = 0;

	m_iGeneLength = 0;

	m_iGroup = 0;

	m_bBusy = true;

	m_bSolved = false;

	CreateStartPopulation();
}

void CgaQueen::CreateStartPopulation()
{
	srand(rand());
	CGenome *temp;
	for(int i = 0; i < m_iPopSize; i++)
		//temp.CGnome(Queen);
	{
		temp = new CGenome;
		temp->CGenom(m_iChromoLength);
		m_vecGenomes.push_back(*temp);
	}

}

void CgaQueen::ShowChromo()
{
	for(m_vecGenomes_it = m_vecGenomes.begin();
		m_vecGenomes_it != m_vecGenomes.end();
		m_vecGenomes_it++)
	{
		m_vecGenomes_it->ShowBits();
	}
}

bool CgaQueen::UpdateFitnessScores()
{
	int i = 0;
	int wrong = 0;
	m_dTotalFitnessScore = 0;
	for( i = 0; i < m_iPopSize; i++)
	{
		//*
		m_vecGenomes[i].UpdateFitnessScore();
		if(m_vecGenomes[i].dFitness == m_dBestFitnessScore)
		{
			m_CSolve = m_vecGenomes[i];
			return true;
		}
		//*/
		m_dTotalFitnessScore+=m_vecGenomes[i].dFitness;
	}
	return false;

}

int CgaQueen::RouletteWheelSelection()
{
	int num = 0;
	//srand(rand());
	double fSlice = (double)(rand()%(int)(m_dTotalFitnessScore*1000))/1000;
	double cfTotal = 0;
	for(int i = 0; i < m_iPopSize; i++)
	{
		cfTotal +=  m_vecGenomes[i].dFitness;
		if(cfTotal > fSlice)
		{
			num = i;
			break;
		}

	}
	return num;
}
void CgaQueen::CrossOverPMX(vector<int>&mum,vector<int>&dad,vector<int>&baby1,vector<int>&baby2)
{

		//不進行雜交的情況
	if((double)(rand()%1000)/1000 < m_dCrossRate || mum == dad)
	{ 
		baby1 = dad;
		baby2 = mum;
		return;
	}
	//雜交
	//srand(rand());
	int pos1 = rand()%m_iChromoLength;
	int pos2 = rand()%m_iChromoLength;
	do
	{
		pos2 = rand()%m_iChromoLength;
	}while(pos2 > pos1);
	//沿著染色體的長度隨機選擇一個點斷開染色體
	//srand(rand());
	int end = rand()%(m_iChromoLength-pos1);
	//int end = rand()%m_iChromoLength;
	baby1 = dad;
	baby2 = mum;
	int i = 0,j = 0;
	for(i = pos1,j = pos2; i <= pos1 + end && i < m_iChromoLength; i++,j++)
	{
		int gene1 = dad[i];
		int gene2 = mum[j];
		if(gene1 != gene2)
		{
			int *posGene1 = find(baby1.begin(),baby1.end(),gene1);
			int *posGene2 = find(baby1.begin(),baby1.end(),gene2);	
			swap(*posGene1,*posGene2);
			posGene1 = find(baby2.begin(),baby2.end(),gene1);
			posGene2 = find(baby2.begin(),baby2.end(),gene2);
			swap(*posGene1,*posGene2);
		}
	}
	/*
	cout<<"pos1 = "<<pos1<<endl;
	cout<<"end  = "<<end<<endl;
	cout<<"pos2 = "<<pos2<<endl;
	cout<<"dad   = ";
	for(i = 0; i < m_iChromoLength; i++)
	{
		cout<<dad[i]+1<<' ';
	}
	cout<<endl;
	cout<<"mum   = ";
	for(i = 0; i < m_iChromoLength; i++)
	{
		cout<<mum[i]+1<<' ';
	}
	cout<<endl;
	cout<<"baby1 = ";
	for(i = 0; i < m_iChromoLength; i++)
	{
		cout<<baby1[i]+1<<' ';
	}
	cout<<endl;
	cout<<"baby2 = ";
	for(i = 0; i < m_iChromoLength; i++)
	{
		cout<<baby2[i]+1<<' ';
	}
	cout<<endl;
	//*/
}

void CgaQueen::CrossOver(vector<int>&mum,vector<int>&dad,vector<int>&baby1,vector<int>&baby2)
{
	//不進行雜交的情況
	if((double)(rand()%1000)/1000 < m_dCrossRate || mum == dad)
	{
		baby1 = dad;
		baby2 = mum;
		return;
	}
	//雜交
	srand(rand());
	int pos = rand()%m_iChromoLength;
	//沿著染色體的長度隨機選擇一個點斷開染色體
	for(int i = 0; i < pos; i++)
	{
		baby1.push_back(dad[i]);
		baby2.push_back(mum[i]);
	}
	for(i = pos; i < m_iChromoLength; i++)
	{
		baby1.push_back(mum[i]);
		baby2.push_back(dad[i]);
	}
}

void CgaQueen::Mutate(vector<int>&baby)
{
	//根據變異率確定是否變異
	//srand(rand());
	if((double)(rand()%1000)/1000 > m_dMutationRate)
	{
		return;
	}
	/*插入變異
	int pos = rand()%m_iChromoLength;
	int gene = baby[pos];
	baby.erase(baby.begin()+pos);
	int insert_pos = rand()%m_iChromoLength;
	baby.insert(baby.begin()+pos,gene);
	//*/


	//*交換變異
	//選擇第一個基因
	int pos1 = rand()%m_iChromoLength;
	//選擇第二個基因
	int pos2 = rand()%m_iChromoLength;
	while(pos1 == pos2)
	{
		////srand(rand());
		pos2 = rand()%m_iChromoLength;
	}
	//交換位置
	swap(baby[pos1],baby[pos2]);
	//*/
	/*
	cout<<"變異成功!"<<endl;
	for(int i = 0; i < m_iChromoLength; i++)
	{
		cout<<baby[i]+1<<' ';
	}
	cout<<endl;
	//*/
}

void CgaQueen::Epoach()
{
	//找到可行解了

	if(UpdateFitnessScores() == true)
	{
		m_bSolved = true;
		m_bBusy = false;
		return;
	}
	for(int i = 1; i < m_iPopSize; i++) //收斂到同一個解退出
	{
		if(m_vecGenomes[i].vecBits != m_vecGenomes[0].vecBits)
		{
			break;
		}
	}
	if(i == m_iPopSize)
	{
		m_bSolved = false;
		m_bBusy = false;
		return;
	}
	//創建一個新群體
	int Babies = 0;
	//存儲嬰兒
	vector<CGenome> vecBabyGenomes;
	//賭輪選擇
	while(Babies < m_iPopSize)
	{
		CGenome mum = m_vecGenomes[RouletteWheelSelection()];
		CGenome dad = m_vecGenomes[RouletteWheelSelection()];
	
		CGenome baby1,baby2;
		baby1.CGenom(m_iChromoLength);
		baby2.CGenom(m_iChromoLength);
		//雜交
		//CrossOver(mum.vecBits,dad.vecBits,baby1.vecBits,baby2.vecBits);
		CrossOverPMX(mum.vecBits,dad.vecBits,baby1.vecBits,baby2.vecBits);
		//變異
		Mutate(baby1.vecBits);
		Mutate(baby2.vecBits);
		Babies += 2;
		vecBabyGenomes.push_back(baby1);
		vecBabyGenomes.push_back(baby2);
		/*
		cout<<"mum   = ";
		mum.ShowBits();
		cout<<"dad   = ";
		dad.ShowBits();
		cout<<"baby1 = ";
		baby1.ShowBits();
		cout<<"baby2 = ";
		baby2.ShowBits();
		//*/
	}
	m_vecGenomes = vecBabyGenomes;
	m_iGeneration++;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品99久久久久| 中文字幕久久午夜不卡| 亚洲成人中文在线| 欧美一a一片一级一片| 一区二区在线观看免费视频播放 | 国产午夜精品一区二区三区嫩草| 国产一区二三区| 国产亚洲1区2区3区| 成人美女视频在线观看| 中文字幕乱码一区二区免费| 成人aaaa免费全部观看| 亚洲资源在线观看| 日韩欧美中文一区| 成熟亚洲日本毛茸茸凸凹| 一区二区三区鲁丝不卡| 欧美一区二区三区在线电影 | 日韩福利视频导航| 久久久久久久精| 在线一区二区三区四区| 日韩国产欧美在线播放| 国产日韩欧美精品在线| 色综合久久中文字幕综合网| 日韩国产欧美视频| 国产精品久久久久毛片软件| 欧美视频第二页| 国产在线一区观看| 国产精品大尺度| 91精品国产综合久久久蜜臀粉嫩 | 亚洲国产精品久久艾草纯爱| 国产日韩欧美一区二区三区乱码 | 国产女同互慰高潮91漫画| 3751色影院一区二区三区| 99v久久综合狠狠综合久久| 日日摸夜夜添夜夜添国产精品 | 日本韩国欧美在线| 韩日欧美一区二区三区| 日韩二区在线观看| 日韩码欧中文字| 国产欧美综合色| 国产欧美精品在线观看| 久久久久久久综合日本| 欧美一区二区二区| 8v天堂国产在线一区二区| 91亚洲精品一区二区乱码| 国产白丝精品91爽爽久久 | 日韩黄色小视频| 美女视频一区二区| 国产一区二区三区精品视频| 久久99久久99精品免视看婷婷| 美女视频免费一区| 国模冰冰炮一区二区| 国产成人av一区二区三区在线| 国产一区二区在线电影| 国产馆精品极品| 日本国产一区二区| 欧美一区二区三区免费在线看| 91精品国产色综合久久久蜜香臀| 欧美一卡2卡3卡4卡| 久久久精品欧美丰满| 亚洲人成精品久久久久| 亚洲成av人影院| 轻轻草成人在线| 国产成人精品午夜视频免费| 91麻豆自制传媒国产之光| 5566中文字幕一区二区电影| 精品国产一区二区三区不卡| 国产精品第四页| 免费精品视频最新在线| 春色校园综合激情亚洲| 欧美日韩你懂的| 久久精品视频在线看| 亚洲一区二区三区四区的| 美女视频黄 久久| 91国产福利在线| 国产精品久久免费看| 精彩视频一区二区| 欧美主播一区二区三区美女| 精品日韩一区二区三区| 亚洲一区二区欧美日韩 | 日韩成人免费看| 欧美综合亚洲图片综合区| 久久综合色播五月| 精品一区二区三区在线视频| 欧美日韩一区二区三区在线看| 国产日韩欧美精品一区| 久久国产欧美日韩精品| 欧美三级视频在线观看| 亚洲欧洲av色图| 高清在线观看日韩| 久久嫩草精品久久久久| 秋霞午夜av一区二区三区| 色综合天天综合狠狠| 中文字幕五月欧美| 国产a久久麻豆| 国产日产欧产精品推荐色| 国产在线播放一区二区三区| wwwwxxxxx欧美| 国内偷窥港台综合视频在线播放| 欧美日韩日日骚| 日韩福利视频导航| 精品剧情在线观看| 成人一区在线观看| 综合自拍亚洲综合图不卡区| 99这里只有精品| 一区二区三区四区在线免费观看| 色综合欧美在线视频区| 日韩高清在线不卡| 国产喷白浆一区二区三区| www.亚洲人| 日本伊人午夜精品| 久久久久久免费| 色呦呦网站一区| 麻豆精品久久久| 国产精品久久久久一区二区三区 | 日韩一区日韩二区| 777xxx欧美| 91社区在线播放| 久久国产尿小便嘘嘘| 亚洲精品国久久99热| 欧美精品一区二区在线播放| 色婷婷久久久亚洲一区二区三区| 日本欧美一区二区三区| 亚洲图片你懂的| 欧美国产日产图区| 欧美一区二区三区在线观看视频| 国产九色精品成人porny| 亚洲国产成人高清精品| 国产精品久久久99| 欧美mv日韩mv| 欧美精品99久久久**| 99re8在线精品视频免费播放| 日韩成人一级大片| 亚洲一区国产视频| 中文字幕日韩欧美一区二区三区| 日韩精品一区二区三区在线观看| 欧美精品视频www在线观看| 成人av网站免费| 成人在线综合网站| 丁香婷婷综合色啪| 国产精品资源站在线| 精品亚洲成av人在线观看| 美国一区二区三区在线播放| 亚洲卡通欧美制服中文| 亚洲精品第1页| 亚洲国产毛片aaaaa无费看| 樱花影视一区二区| 亚洲一区二区三区激情| 亚洲成人午夜影院| 免费观看在线色综合| 精品一区二区三区免费播放| 麻豆91在线播放免费| 国产综合久久久久久鬼色 | 亚洲一区二区三区视频在线| 亚洲第一成人在线| 美女视频免费一区| 成人高清视频免费观看| 91丝袜美腿高跟国产极品老师 | 麻豆精品一二三| 国产成人日日夜夜| 在线中文字幕一区二区| 91麻豆精品国产91久久久久 | 中文字幕欧美日韩一区| 亚洲国产成人av好男人在线观看| 无码av中文一区二区三区桃花岛| 久久成人18免费观看| 91网站最新网址| 欧美一区二区三区视频免费 | 色偷偷久久人人79超碰人人澡| 欧美二区三区91| 中文字幕日韩一区| 国模一区二区三区白浆| 日韩一级免费一区| 国产精品国产精品国产专区不蜜| 青青草91视频| 欧美视频一区二区三区| 国产免费成人在线视频| 日韩av不卡在线观看| 日本韩国精品一区二区在线观看| 亚洲精品在线电影| 性做久久久久久免费观看欧美| av中文一区二区三区| 久久精品亚洲麻豆av一区二区| 天涯成人国产亚洲精品一区av| 国产成人高清视频| 久久久久九九视频| 激情久久五月天| 精品国产伦理网| 久久精品久久精品| 日韩欧美国产一区二区三区 | 亚洲男女一区二区三区| 国产91在线观看| 国产亚洲成av人在线观看导航| 蜜臀久久99精品久久久画质超高清| 69堂国产成人免费视频| 亚洲h在线观看| 欧美一级二级在线观看| 日日骚欧美日韩| 久久网这里都是精品| 国产精品综合久久| 亚洲女爱视频在线|