本文实例讲述了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++实现简单遗传算法相关推荐

  1. 遗传算法的c++语言程,遗传算法 C++的程序

    遗传算法 C++的程序 #include #include #include /* Change any of these parameters to match your needs */ #def ...

  2. 简单的java图形_简单图形的输出_Java语言程

    简单图形的输出_Java语言程 3.5.4 简单图形的输出 [例3-26] 编程显示以下图形(共N行,N由键盘输入). 程序运行结果:略. 分析与思考:(1)设N=5 第1行 4个空格=5-1 1个& ...

  3. 航空航天大类C语言程设第三次练习赛

    航空航天大类C语言程设第三次练习赛 第四期更新, 鸽子博主终于更新第三次练习赛了 (A题)求区间交并集 多行数据,每行有两个数,用空格分开,表示每个区间的下和上界,保证是合法的非空集,而且得到的并集是 ...

  4. c语言程构成,构成C语言程序的基本单位是()

    摘要: 构成下列性骨折骨折哪些稳定属于.基本特点)的有(法具税收实体.必须下列行为销售货物视同,单位值税的是应征收增.... 构成下列性骨折骨折哪些稳定属于. 语言程保全提之机关的前采取措施一是税务税 ...

  5. C语言面试题-这些简单的你能很快的写出来吗?

    C语言面试题-这些简单的你能很快的写出来吗? 在职场上,面试已经成了我们经常讨论的一个话题,但是当我们在求职面试的时候总是会遇到各种问题,在这里我就给大家讲解一些C语言的面试题! 面试题一: 编写一个 ...

  6. R语言使用caret包构建遗传算法树模型(Tree Models from Genetic Algorithms )构建回归模型、通过method参数指定算法名称

    R语言使用caret包构建遗传算法树模型(Tree Models from Genetic Algorithms  )构建回归模型.通过method参数指定算法名称.通过trainControl函数控 ...

  7. VC开发多语言界面支持的简单方法

    VC开发多语言界面支持的简单方法 作者:成晓旭 (需要完整源代码请留言) 最近在做一个小程序,要求实现对多语言界面显示支持功能,并且,界面显示内容用户能够自己设置. 初步设计用INI文件来配置显示内容 ...

  8. 《零基础看得懂的C语言入门教程 》——(二)C语言没那么难简单开发带你了解流程

    一.学习目标 了解DevC集成开发环境 了解集成开发环境 了解HelloWorld程序 了解HelloWorld程序的编写方法 目录 C语言真的很难吗?那是你没看这张图,化整为零轻松学习C语言. 第一 ...

  9. 顺序表输入栈元素c语言,C语言数据结构之栈简单操作

    C语言数据结构之栈简单操作 实验: 编写一个程序实现顺序栈的各种基本运算,并在此基础上设计一个主程序,完成如下功能: (1)初始化顺序栈 (2)插入元素 (3)删除栈顶元素 (4)取栈顶元素 (5)遍 ...

最新文章

  1. layui ajax流加载,layui中流加载layui.flow
  2. 一步一步学Silverlight 2系列(35):升级Silverlight 2 Beta 1应用程序到Beta 2
  3. tank html5,index.html
  4. JavaFX FXML场景编辑器使用示例
  5. Deep Learning 论文笔记 (2): Neural network regularization via robust weight factorization
  6. 微信小程序 - 基础 - 003 - WEUI - 基本表单组件 - form - 页面数据提交和获取 - 01
  7. java图片转换为数据流_OpenCV 读取数据流图片
  8. 正则表达式JavaScript版本回顾笔记背诵版本
  9. python绘制多条不同x轴曲线_python matlibplot绘制多条曲线图
  10. 动态规划:leetcode 416 分割等和子集(背包问题应用)
  11. 智能对话训练师进阶本领:复杂对话流程处理
  12. CS224N笔记——深入GRU和LSTM
  13. easyui tree json php,easyui tree json
  14. ISO27001认证办理流程及2022年补贴政策汇总
  15. 最新版:如何到Redhat官网下载RedHat镜像及申请试用安装序号
  16. Qt播放多路视频的理解
  17. C语言的printf输出格式控制
  18. 软件人员kpi制定模板_员工绩效考核评分表模板
  19. Tallest buildings/skyscrapers in the world
  20. python udp socket远程主机强迫关闭_Python 远程主机强迫关闭了一个现有的连接

热门文章

  1. 华为云3大体系化防护实践,保障金融业云上数据安全
  2. SpringCloud注册与发现Eureka
  3. lisp医院化验系统_浅谈医院化验室信息系统(LIS)的建设
  4. mysql5.6.40免安装版配置方案
  5. GraphX:基于Spark的弹性分布式图计算系统
  6. html倒计时timer,js如何使用定时器实现倒计时功能
  7. java 删除list_Java中如何优雅地删除List中的元素
  8. LoRa、LoRaWAN及网关相关技术介绍
  9. linux批量文件编码转换,Linux系统批量转换文件编码脚本
  10. java常问的报错_java常见报错及解决