我在代码中遇到浮点异常,但无法对其进行排序。我不知道问题是什么。不太擅长C ++程序,只是通过给出的公式。 请帮帮我:
程序:
#include<iostream.h>
#include<conio.h>
#include <stdlib.h>
void main()
{
clrscr();
int a,b,c,d,ctr,j,Q=1,K=1 ;
float q0=0.7, p = 0.5 ;
int phe[3][3];
double dist[3][3] , mem[3][3],exp[3][3],eplt[3][3], rnd;
cout<<"enter the iterations, cities , ants ";
cin>>a>>b>>c;
for (int i=0;i<3;i++)
{
for (j=0;j<3;j++)
{
dist[i][j]=(double)rand()/(double)RAND_MAX;
if (i==j)
dist[i][j]=0;
}
}
for (i=0;i<3;i++)
{
for (j=0;j<3;j++)
{
cout<< dist[i][j]<<"\t";
}
cout<<"\n";
}
cout<<"pheromone matrix "<<endl;
for (i=0;i<3;i++)
{
for (j=0;j<3;j++)
{
if (i==j)
phe[i][j]=0;
else
phe[i][j]=1;
}
}
for ( i=0;i<3;i++)
{
for ( j=0;j<3;j++)
{
cout<< phe[i][j]<<"\t";
}
cout<<"\n";
}
cout<< "after iteration "<<endl;
for (i=0;i<3;i++)
{
ctr=0;
for (int k=0;k<3;k++)
{
// mem[i][k]=(rand()%b)+1;
// cout<<"memory"<<mem[i][k]<<"\n";
rnd= (double)rand()/(double)RAND_MAX;
cout<<"hhhhhhh"<<rnd;
if (rnd<=q0)
{
cout<<"Exploitation\n";
eplt[i][ctr] =(p*phe[i][k])+(Q/K);
}
else
{
cout<<"EXPLORATION\n";
eplt[i][ctr]= phe[i][k]/dist[i][k];
}
ctr++;
}
}
for (i=0;i<3;i++)
{
for (int k=0;k<3;k++)
{
cout <<eplt[i][k]<<"\t";
}
cout<<"\n";
}
getch();
}
我在“迭代后”完成后的第一个循环后收到错误。 这是输出:
进入迭代,城市,蚂蚁3 4 4
0 0.003967 0.335154 0.033265 0 0.2172 0.536973 0.195776 0
信息素矩阵 0 1 1 1 0 1 1 1 0 迭代后hhhhhhh0.949919EXPLORATION 浮点错误:域。 异常程序终止
答案 0 :(得分:5)
乍一看:你在说这句话吗
eplt[i][ctr]= phe[i][k]/dist[i][k];
i = 0且k = 0?从初始化开始,dist [0] [0] = 0,你将得到除零异常。
答案 1 :(得分:3)
我认为这一行(在cout<<"EXPLORATION\n";
之后:
eplt[i][ctr]= phe[i][k]/dist[i][k];
是问题所在。当i == k时,则dist [i] [k] == 0.0。