遗传算法的c++语言程,C++实现简单遗传算法
本文实例讲述了C++实现简单遗传算法。分享给大家供大家参考。具体实现方法如下:
//遗传算法 GA
#include
#include
#include
using namespace std;
const int L=5; //定义编码的长度
int f(int x) //定义测设函数f(x)
{
int result;
result=x*x*x-60*x*x+900*x+100;
return result;
}
int main(int argc,char *argv[])
{
int a(0),b(32); //定义x的定义域范围
const int pop_size=8; //定义种群大小
// int L; //指定编码的长度
const int NG=20; //指定种群最大的繁殖的代数
int t=0; //当前繁殖的代数
int p[pop_size]; //定义种群
int q[pop_size]; //定义繁殖种群 即种群的下一代
srand(6553); //定义随机数生成的种子
double sum; //适值总和
double avl_sum; //适度平均值
double p_probability[pop_size]; //适值概率
double pp[pop_size];
double pro; //定义随机生成的概率
float pc=0.90; //定义交叉的概率
float pm=0.05; //定义变异的概率
cout<
for(int i=0;i
{
p[i]=rand()%31;
cout<
}
cout<
cout<
void Xover(int &,int &); //声明交叉函数
//当停止准则不满足 即繁殖代数没到最大代数 ,继续繁殖
while(t<=NG)
{
cout<
sum=0.0;
for(int i=0;i
{
q[i]=p[i];
cout<
}
cout<
for(int i=0;i
sum +=f(p[i]);
avl_sum=sum/pop_size;
cout<
cout<
for(int i=0;i
{
p_probability[i]=f(p[i])/sum;
if(i==0)
{
pp[i]=p_probability[i];
cout<
}
else
{
pp[i]=p_probability[i]+pp[i-1];
cout<
}
//cout<
}
//选择双亲
for(int i=0;i
{
pro=rand()%1000/1000.0;
if(pro>=pp[0]&&pro
p[i]=q[0];
else if(pro>=pp[1]&&pro
p[i]=q[1];
else if(pro>=pp[2]&&pro
p[i]=q[2];
else if(pro>=pp[3]&&pro
p[i]=q[3];
else if(pro>=pp[4]&&pro
p[i]=q[4];
else
p[i]=q[5];
}
//杂交算子
int r=0;
int z=0;
for(int j=0;j
{
pro=rand()%1000/1000.0;
if(pro
{
++z;
if(z%2==0)
Xover(p[r],p[j]);
else
r=j;
}
}
//变异算子
for(int i=1;i<=pop_size;i++)
for(int j=0;j
{
pro=rand()%1000/1000.0; //在【0,1】区间产生随机数
if(pro
{
bitsetv(p[i]);
v.flip(j);
p[i]=v.to_ulong();
}
}
t++;
cout<
}
cout<
for(int i(0);i
{
cout<
}
cout<
return 0;
}
//定义杂交操作
void Xover(int &a,int &b)
{
int pos; //随机生成杂交点 即第几个分量进行相互交换
pos=rand()%5+1; //在n个分量中,随机确定第pos个分量
int j,k;
j=pos;
k=pos;
bitsete(a);
bitsetf(b); //前pos个分量进行相互交换
bitsetg;
bitseth;
for(int i=0;i
{
if(e[i]==1)
g.set(i);
}
for(int i=0;i
{
if(f[i]==1)
h.set(i);
}
for(j;j
{
if(f[j]==1)
g.set(j);
}
for(k;k
{
if(e[k]==1)
h.set(k);
}
a=g.to_ulong();
b=h.to_ulong();
}
希望本文所述对大家的C++程序设计有所帮助。
遗传算法的c++语言程,C++实现简单遗传算法相关推荐
- 遗传算法的c++语言程,遗传算法 C++的程序
遗传算法 C++的程序 #include #include #include /* Change any of these parameters to match your needs */ #def ...
- 简单的java图形_简单图形的输出_Java语言程
简单图形的输出_Java语言程 3.5.4 简单图形的输出 [例3-26] 编程显示以下图形(共N行,N由键盘输入). 程序运行结果:略. 分析与思考:(1)设N=5 第1行 4个空格=5-1 1个& ...
- 航空航天大类C语言程设第三次练习赛
航空航天大类C语言程设第三次练习赛 第四期更新, 鸽子博主终于更新第三次练习赛了 (A题)求区间交并集 多行数据,每行有两个数,用空格分开,表示每个区间的下和上界,保证是合法的非空集,而且得到的并集是 ...
- c语言程构成,构成C语言程序的基本单位是()
摘要: 构成下列性骨折骨折哪些稳定属于.基本特点)的有(法具税收实体.必须下列行为销售货物视同,单位值税的是应征收增.... 构成下列性骨折骨折哪些稳定属于. 语言程保全提之机关的前采取措施一是税务税 ...
- C语言面试题-这些简单的你能很快的写出来吗?
C语言面试题-这些简单的你能很快的写出来吗? 在职场上,面试已经成了我们经常讨论的一个话题,但是当我们在求职面试的时候总是会遇到各种问题,在这里我就给大家讲解一些C语言的面试题! 面试题一: 编写一个 ...
- R语言使用caret包构建遗传算法树模型(Tree Models from Genetic Algorithms )构建回归模型、通过method参数指定算法名称
R语言使用caret包构建遗传算法树模型(Tree Models from Genetic Algorithms )构建回归模型.通过method参数指定算法名称.通过trainControl函数控 ...
- VC开发多语言界面支持的简单方法
VC开发多语言界面支持的简单方法 作者:成晓旭 (需要完整源代码请留言) 最近在做一个小程序,要求实现对多语言界面显示支持功能,并且,界面显示内容用户能够自己设置. 初步设计用INI文件来配置显示内容 ...
- 《零基础看得懂的C语言入门教程 》——(二)C语言没那么难简单开发带你了解流程
一.学习目标 了解DevC集成开发环境 了解集成开发环境 了解HelloWorld程序 了解HelloWorld程序的编写方法 目录 C语言真的很难吗?那是你没看这张图,化整为零轻松学习C语言. 第一 ...
- 顺序表输入栈元素c语言,C语言数据结构之栈简单操作
C语言数据结构之栈简单操作 实验: 编写一个程序实现顺序栈的各种基本运算,并在此基础上设计一个主程序,完成如下功能: (1)初始化顺序栈 (2)插入元素 (3)删除栈顶元素 (4)取栈顶元素 (5)遍 ...
最新文章
- layui ajax流加载,layui中流加载layui.flow
- 一步一步学Silverlight 2系列(35):升级Silverlight 2 Beta 1应用程序到Beta 2
- tank html5,index.html
- JavaFX FXML场景编辑器使用示例
- Deep Learning 论文笔记 (2): Neural network regularization via robust weight factorization
- 微信小程序 - 基础 - 003 - WEUI - 基本表单组件 - form - 页面数据提交和获取 - 01
- java图片转换为数据流_OpenCV 读取数据流图片
- 正则表达式JavaScript版本回顾笔记背诵版本
- python绘制多条不同x轴曲线_python matlibplot绘制多条曲线图
- 动态规划:leetcode 416 分割等和子集(背包问题应用)
- 智能对话训练师进阶本领:复杂对话流程处理
- CS224N笔记——深入GRU和LSTM
- easyui tree json php,easyui tree json
- ISO27001认证办理流程及2022年补贴政策汇总
- 最新版:如何到Redhat官网下载RedHat镜像及申请试用安装序号
- Qt播放多路视频的理解
- C语言的printf输出格式控制
- 软件人员kpi制定模板_员工绩效考核评分表模板
- Tallest buildings/skyscrapers in the world
- python udp socket远程主机强迫关闭_Python 远程主机强迫关闭了一个现有的连接
热门文章
- 华为云3大体系化防护实践,保障金融业云上数据安全
- SpringCloud注册与发现Eureka
- lisp医院化验系统_浅谈医院化验室信息系统(LIS)的建设
- mysql5.6.40免安装版配置方案
- GraphX:基于Spark的弹性分布式图计算系统
- html倒计时timer,js如何使用定时器实现倒计时功能
- java 删除list_Java中如何优雅地删除List中的元素
- LoRa、LoRaWAN及网关相关技术介绍
- linux批量文件编码转换,Linux系统批量转换文件编码脚本
- java常问的报错_java常见报错及解决