Может кто-нибудь помочь мне выяснить, почему у меня ошибка времени выполнения в моем коде при использовании gnuWin32. Ошибка исчезает, когда функция GaussSeidel прокомментирована. Я попробовал онлайн-компилятор GNU GCC v4.8.3 и, похоже, там работает нормально. C++ 14 на ideone.com дал мне ошибку во время выполнения двойной свободной или коррупции. Я прикрепил простую версию моего кода, который страдает от этой ошибки. Благодарю.Двойная бесплатная или поврежденная ошибка
#include <iostream>
#include <cmath>
void GaussSeidel(double** const aa, double* const bb, double* xvec, const int nn, int mm)
{
int i = 0, j = 0;
double *ynew=NULL, *yold=NULL, EE=20.0;
ynew=new double[nn];
yold=new double[nn];
while (mm > 0 && EE>0.00001) {
EE=0.0;
for (i = 0; i < nn; i++) {
yold[i]=ynew[i];
ynew[i] = bb[i]/aa[i][i];
for (j = 0; j < nn; j++) {
if (j == i) continue;
ynew[i] = ynew[i] - (aa[i][j] * xvec[j]/ aa[i][i]);
xvec[i] = ynew[i];
}
if (std::abs(ynew[i]-yold[i])>EE) EE=std::abs(ynew[i]-yold[i]);
}
mm--;
}
std::cout << mm << " " << EE << std::endl;
for (j = 0; j < nn; j++)
xvec[i] = ynew[i];
delete [] ynew;
delete [] yold;
}
int main (void)
{
int i, j;
const int Np=100;
double **Infl=NULL, *Source=NULL, *FpdPhi0=NULL;
Source=new double[Np];
FpdPhi0=new double[Np];
Infl = new double *[Np]; for(i = 0; i < Np; i++) Infl[i] = new double[Np];
for (j=0; j<Np; j++){
for (i=0; i<Np; i++){
if (i==j){
Infl[j][i]=1.0;
}
else {
Infl[j][i]=0.0;
}
}
Source[j]=4.0;
FpdPhi0[j]=0.1;
}
GaussSeidel(Infl, Source, FpdPhi0, Np, 300);
for(i = 0; i < Np; i++) delete [] Infl[i];
delete [] Infl;
delete [] Source;
delete [] FpdPhi0;
return 0;
}
Используйте 'std :: vector' и избавьтесь от всего бесполезного управления ручной памятью. – Chad
Кроме того, ваш GaussSeidel имеет утечку памяти, если второй вызов 'new []' в этой функции вызывает исключение. Избегайте всех этих проблем с помощью 'std :: vector'. – PaulMcKenzie
Это хорошая идея ограничить область переменных индекса for-loop. – molbdnilo