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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ga.c

?? -C語言精彩編程百例-附書源碼
?? C
字號:
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include <time.h>

#define SUM 20            //總共的染色體數(shù)量
#define MAXloop 1200       //最大循環(huán)次數(shù)
#define error 0.01        //若兩次最優(yōu)值之差小于此數(shù)則認為結(jié)果沒有改變
#define crossp 0.7        //交叉概率
#define mp 0.04           //變異概率

struct gen                //定義染色體結(jié)構(gòu)
{
	int info;        
	float suitability;
};
struct gen gen_group[SUM];//定義一個含有20個染色體的組
struct gen gen_new[SUM];  

struct gen gen_result;    //記錄最優(yōu)的染色體
int result_unchange_time; //記錄在error前提下最優(yōu)值為改變的循環(huán)次數(shù)

struct log                //形成鏈表,記錄每次循環(huán)所產(chǎn)生的最優(yōu)的適應度
{
	float suitability;
	struct log *next;
}llog,*head,*end;
int log_num;              //鏈表長度

void initiate();          
void evaluation(int flag);
void cross();
void selection();
int  record();
void mutation();
void showresult(int);

int   randsign(float p);
int   randbit(int i,int j);
int   randnum();
int   convertionD2B(float x);
float convertionB2D(int x);
int   createmask(int a);

void main()
{
	int i,flag;
	flag=0;
	initiate();
    evaluation( 0 );
	for( i = 0 ; i < MAXloop ; i++ )
	{
		cross();
		evaluation( 1 );
		selection();
		if( record() == 1 )
		{
			flag = 1;
			break;
		}
		mutation();
	}
	showresult( flag );
}

void initiate()
{
	int i , stime;	
	long ltime;
	ltime=time(NULL);
	stime=(unsigned)ltime/2;
	srand(stime);
	for( i = 0 ; i < SUM ; i++ )
	{
		gen_group[i].info = randnum();		 
	}
	gen_result.suitability=1000;
	result_unchange_time=0;
	head=end=(struct log *)malloc(sizeof(llog));
	if(head==NULL)
	{
		printf("\n內(nèi)存不夠!\n");
		exit(0);
	}
	end->next = NULL;
	log_num = 1;
}

void evaluation(int flag)
{
	int i,j;
	struct gen *genp;
	int gentinfo;
	float gentsuitability;
	float x;
	if( flag == 0 )
		genp = gen_group;
	else genp = gen_new;
	for(i = 0 ; i < SUM ; i++)//計算各染色體對應的表達式值
	{
		x = convertionB2D( genp[i].info );
		genp[i].suitability = x*(x*(x*(x*(x*(x-10)-26)+344)+193)-1846)-1680;
	}
	for(i = 0 ; i < SUM - 1 ; i++)//按表達式的值進行排序,
	{
		for(j = i + 1 ; j < SUM ; j++)
		{
			if( genp[i].suitability > genp[j].suitability )
			{
				gentinfo = genp[i].info;
				genp[i].info = genp[j].info;
				genp[j].info = gentinfo;
				
				gentsuitability = genp[i].suitability;
				genp[i].suitability = genp[j].suitability;
				genp[j].suitability = gentsuitability;		
			}
		}
	}
}

void cross()
{
	int i , j , k ;
	int mask1 , mask2;
	int a[SUM];
	for(i = 0 ; i < SUM ; i++)  a[i] = 0;
	k = 0;
	for(i = 0 ; i < SUM ; i++)
	{
		if( a[i] == 0)
		{
			for( ; ; )//隨機找到一組未進行過交叉的染色體與a[i]交叉
			{
   				j = randbit(i + 1 , SUM - 1);
				if( a[j] == 0)	break;
			}
			if(randsign(crossp) == 1)
			{
				mask1 = createmask(randbit(0 , 14));
				mask2 = ~mask1;
				gen_new[k].info = (gen_group[i].info) & mask1 + (gen_group[j].info) & mask2;
				gen_new[k+1].info=(gen_group[i].info) & mask2 + (gen_group[j].info) & mask1;
				k = k + 2;
			}
			else 
			{
				gen_new[k].info=gen_group[i].info;
				gen_new[k+1].info=gen_group[j].info;
				k=k+2;
			}
			a[i] = a[j] = 1;
		}
	}
}

void selection()
{
	int i , j , k;
	j = 0;
	i = SUM/2-1;
	if(gen_group[i].suitability < gen_new[i].suitability)
	{
		for(j = 1 ; j < SUM / 2 ; j++)
		{
			if(gen_group[i+j].suitability > gen_new[i-j].suitability)
				break;
		}
	}
	else
		if(gen_group[i].suitability>gen_new[i].suitability)
		{
			for(j=-1;j>-SUM/2;j--)
			{
				if(gen_group[i+j].suitability<=gen_new[i-j].suitability)
					break;
			}
		}
	for(k=j;k<SUM/2+1;k++)
	{
		gen_group[i+k].info = gen_new[i-k].info;
		gen_group[i+k].suitability = gen_new[i-k].suitability;
	}	
}

int record()
{
	float x;	
	struct log *r;
	r=(struct log *)malloc(sizeof(llog));
	if(r==NULL)
	{
		printf("\n內(nèi)存不夠!\n");
		exit(0);
	}
	r->next = NULL;
	end->suitability = gen_group[0].suitability;
	end->next = r;
	end = r;
	log_num++;

	x = gen_result.suitability - gen_group[0].suitability;
	if(x < 0)x = -x;
	if(x < error)
	{
		result_unchange_time++;
		if(result_unchange_time >= 20)return 1;
	}
	else
	{
		gen_result.info = gen_group[0].info;
		gen_result.suitability = gen_group[0].suitability;
		result_unchange_time=0;
	}
	return 0;
}

void mutation()
{
	int i , j , m;
	float x;
	float gmp;
	int gentinfo;
	float gentsuitability;
	gmp = 1 - pow(1 - mp , 11);//在基因變異概率為mp時整條染色體的變異概率
	for(i = 0 ; i < SUM ; i++)
	{
		if(randsign(gmp) == 1)
		{
			j = randbit(0 , 14);
			m = 1 << j;
			gen_group[i].info = gen_group[i].info^m;
			x = convertionB2D(gen_group[i].info);
			gen_group[i].suitability = x*(x*(x*(x*(x*(x-10)-26)+344)+193)-1846)-1680;
		}
	}
	for(i = 0 ; i < SUM - 1 ; i++)
	{
		for(j = i + 1 ; j < SUM ; j++)
		{
			if(gen_group[i].suitability > gen_group[j].suitability)
			{
				gentinfo = gen_group[i].info;
				gen_group[i].info = gen_group[j].info;
				gen_group[j].info = gentinfo;
				
				gentsuitability = gen_group[i].suitability;
				gen_group[i].suitability = gen_group[j].suitability;
				gen_group[j].suitability = gentsuitability;
			}
		}
	}
}

void showresult(int flag)//顯示搜索結(jié)果并釋放內(nèi)存
{
	int i , j;
	struct log *logprint,*logfree;
	FILE *logf;
	if(flag == 0)
		printf("已到最大搜索次數(shù),搜索失敗!");
	else 
	{
		printf("當取值%f時表達式達到最小值為%f\n",convertionB2D(gen_result.info),gen_result.suitability);
		printf("收斂過程記錄于文件log.txt");
		if((logf = fopen("log.txt" , "w+")) == NULL)
		{
			printf("Cannot create/open file");
			exit(1);
		}
		logprint=head;
		for(i = 0 ; i < log_num ; i = i + 5)//對收斂過程進行顯示
		{
			for(j = 0 ; (j < 5) & ((i + j) < log_num-1) ; j++)
			{
				fprintf(logf , "%20f" , logprint->suitability);
				logprint=logprint->next;				
			}
			fprintf(logf,"\n\n");
		}
	}
	for(i = 0 ; i< log_num ; i++)//釋放內(nèi)存
	{
		logfree=head;
		head=head->next;
		free(logfree);
		fclose(logf);
	}
	getchar();
}

int randsign(float p)//按概率p返回1
{
	if(rand() > (p * 32768))
		return 0;
	else return 1;
}
int randbit(int i, int j)//產(chǎn)生在i與j之間的一個隨機數(shù)
{
	int a , l;
	l = j - i + 1;
	a = i + rand() * l / 32768;
	return a;
}
int randnum()
{
	int x;
	x = rand() / 2;
	return x;
}
float convertionB2D(int x)
{
	float y;
	y = x;
	y = (y - 8192) / 1000;
	return y;
	
}
int convertionD2B(float x)
{
	int g;
	g = (x * 1000) + 8192;
	return g;
}
int createmask(int a)
{
	int mask;
	mask=(1 << (a + 1)) - 1;
	return mask;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产日韩精品一区二区三区在线| 亚洲欧洲日产国产综合网| 91麻豆国产福利精品| 精品一区二区日韩| 成人免费小视频| 亚洲欧洲日韩一区二区三区| 国产欧美精品日韩区二区麻豆天美| 欧美videos中文字幕| 91久久精品一区二区| 成人一二三区视频| av一本久道久久综合久久鬼色| 国产精品一区在线观看乱码| 久久精品国产99国产精品| 激情综合网最新| 久久精品av麻豆的观看方式| 午夜精品福利在线| 奇米一区二区三区av| 日本不卡123| 国内久久婷婷综合| 狂野欧美性猛交blacked| 免费高清成人在线| 国产精品99久久久久| 国产一区二区三区久久悠悠色av| 美女视频网站久久| 大白屁股一区二区视频| 成人免费视频app| 麻豆精品在线视频| 成人网页在线观看| 99久久免费国产| 欧美性欧美巨大黑白大战| 欧美日本一区二区三区四区| 欧美精品久久久久久久久老牛影院| 日韩亚洲欧美成人一区| 日韩欧美国产高清| 久久精品一区二区三区不卡牛牛| 日韩理论电影院| 一区二区三区四区视频精品免费 | 九九精品视频在线看| 国产高清精品网站| 色播五月激情综合网| 在线播放国产精品二区一二区四区 | 国产乱码一区二区三区| 成人爱爱电影网址| 在线视频综合导航| 欧美一级夜夜爽| 中文字幕在线不卡一区二区三区| 亚洲欧洲国产专区| 一区二区国产盗摄色噜噜| 视频在线在亚洲| 国产成人在线网站| 色婷婷激情久久| 日韩欧美国产三级| 欧美zozo另类异族| 久久久九九九九| 亚洲男同1069视频| 首页国产丝袜综合| 久久国产精品99久久久久久老狼| 亚洲一二三四在线观看| 久久精品国产亚洲一区二区三区| 国产精品亚洲一区二区三区在线 | 成人欧美一区二区三区在线播放| 亚洲黄色性网站| 日韩专区在线视频| 不卡一区中文字幕| 欧美一三区三区四区免费在线看| 国产精品无遮挡| 久久国产精品露脸对白| 91精彩视频在线| 欧美三区在线观看| 国产精品久久国产精麻豆99网站| 亚洲成av人片在线观看无码| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 成人免费在线视频观看| 久久电影网站中文字幕| 91麻豆精品在线观看| 欧美无人高清视频在线观看| 国产欧美日韩激情| 日韩成人午夜精品| 色狠狠桃花综合| 国产肉丝袜一区二区| 亚洲成人黄色小说| 欧洲一区二区av| 国产欧美综合在线观看第十页| 亚洲自拍偷拍图区| 91久久精品网| 国产精品免费人成网站| 国产伦精品一区二区三区在线观看| 欧美午夜电影一区| 亚洲欧美成人一区二区三区| av动漫一区二区| 久久婷婷色综合| 亚洲国产一区二区视频| 91论坛在线播放| 国产精品久久久久久亚洲伦| 国产一区二区不卡在线| 欧美一卡在线观看| 亚洲国产综合视频在线观看| 91麻豆精品秘密| 国产精品久久久久毛片软件| 美女尤物国产一区| 日韩一区和二区| 日韩高清不卡在线| 日韩一区二区视频| 午夜精品久久久久久不卡8050| 91网站在线观看视频| 亚洲欧美aⅴ...| 色综合久久99| 国产精品久久久久久久久果冻传媒 | 欧美精品亚洲二区| 一区二区三区在线观看欧美| 91网站在线观看视频| 亚洲精品视频在线观看免费| 成人av片在线观看| 国产午夜精品在线观看| 成人va在线观看| 国产精品久久久久久久蜜臀| 91小视频免费看| 一区二区三区美女视频| 欧美最新大片在线看| 亚洲成av人片一区二区梦乃| 欧美人狂配大交3d怪物一区| 亚洲免费毛片网站| 欧美日韩和欧美的一区二区| 亚洲风情在线资源站| 日韩一区二区三区视频| 九色综合狠狠综合久久| 欧美xxxx在线观看| 91精品国产色综合久久ai换脸 | 亚洲欧洲国产日韩| 成人av电影观看| 一区二区三区国产| 欧美日韩性生活| 天天综合色天天综合| 欧美一区欧美二区| 激情五月婷婷综合网| 久久久一区二区三区捆绑**| 成人午夜在线播放| 亚洲免费av观看| 欧美电视剧免费全集观看| 狠狠色丁香婷综合久久| 日韩伦理免费电影| 欧美日韩国产综合一区二区三区 | 视频一区二区三区在线| 精品捆绑美女sm三区| 国产一区二区伦理片| **网站欧美大片在线观看| 91福利在线观看| 免费成人美女在线观看| 亚洲视频一二三区| 欧美日韩在线观看一区二区| 日韩和欧美一区二区三区| 亚洲国产高清在线观看视频| 91免费观看视频在线| 美国十次了思思久久精品导航| 久久久亚洲高清| 91日韩一区二区三区| 久久精品国产免费看久久精品| 国产日韩欧美一区二区三区综合| www.亚洲国产| 五月天丁香久久| 久久久国产一区二区三区四区小说 | 成人免费av网站| 亚洲高清视频的网址| 欧美一级日韩免费不卡| 国产91精品露脸国语对白| 综合久久综合久久| 久久免费偷拍视频| 色av成人天堂桃色av| 国产精品自在在线| 亚洲综合在线第一页| 26uuu亚洲| 7777精品伊人久久久大香线蕉超级流畅| 国产自产v一区二区三区c| 一区二区三区免费网站| 国产亚洲短视频| 91精品在线麻豆| 欧日韩精品视频| 国产suv一区二区三区88区| 亚洲综合激情小说| 国产午夜精品理论片a级大结局 | 亚洲综合一二三区| 日本一区二区三区电影| 日韩美女在线视频| 精品国产免费久久| 91精品国产综合久久精品app| 成人午夜在线免费| 国产精品亚洲一区二区三区在线| 丝袜亚洲另类丝袜在线| 亚洲欧美激情插 | 久久国产麻豆精品| 亚洲风情在线资源站| 在线观看亚洲一区| 99精品久久免费看蜜臀剧情介绍 | 91猫先生在线| 91蜜桃网址入口| 国产成人h网站| 国产剧情一区在线| 另类成人小视频在线| 亚洲精品日韩专区silk| 欧美激情在线一区二区|