编程C的段错误

时间:2015-04-07 01:10:05

标签: c segmentation-fault numerical-analysis verlet-integration

我正在使用C语言制作速度Verlet方法。 我以为我做得很好。但是,会弹出“分段故障(核心转储)”。每当,我增加向量或数组的大小,x和y。 对于大小n等于且小于1e3,它很好,但是在n = 1e4时,程序会出错。

请有人帮我解决这个问题。 谢谢。

#include <stdio.h>
#include <stdlib.h>
#include <math.h>

double verlet(double t, double x)
{

  double E = 0.252;
  double B = 0.052;
  double a = M_PI/2;

  return -sin(x) + E*cos(t) + B*cos(2*t+a); 
}   

double pverlet(double(*f)(double, double), double dt, double t, double x, double y)
{
    return  x + dt*( y + (dt/2)*f(t, x));
}

double vverlet(double(*g)(double, double), double dt, double t, double x,  double y)
{
    return y + (dt/2) * g(t, x); 
}

int main(void)
{
int i;
double t;

int n = 1e4;
double ti = 0, tf = 1e5, dt = (tf-ti)/n; 

double *x = (double *) malloc(sizeof(double)*n);
double *y = (double *) malloc(sizeof(double)*2*n);

if (x == NULL)
{
    printf("error allocating memory!\n");
    return 1;
}
if (y == NULL)
{
    printf("error allocating memory!\n");
    return 1;
}

for (y[0] = 0, i = 1; i <2*n; i++)
{
    y[i] = vverlet(verlet, dt, ti + dt*(i-1), x[i-1], y[i-1]);
}

for (x[0] = 0, i = 1; i < n; i++)
{
    x[i] = pverlet(verlet, dt, ti + dt*(i-1), x[i-1], y[2*(i-1)]);
}



for (i = 0; i < n; i++)
{
    t = ti + dt * i;
    printf("%e %e %e\n", t, x[i], y[2*i]);  

}

return 0;
free(x);
free(y);
}

1 个答案:

答案 0 :(得分:3)

for (y[0] = 0, i = 1; i <2*n; i++)
{
    y[i] = vverlet(verlet, dt, ti + dt*(i-1), x[i-1], y[i-1]);
}

x定义为0到n-1。