2

こんにちは、基本的な 1D モンテカルロ統合のコードを書こうとしています。そのためには、(別のサブルーチンに格納されている) 関数に入力できる疑似乱数のリストが必要です。乱数のリストにポインターを与えましたが、メインで逆参照しようとすると、「エラー: 型 'double' から型 'double[11]' に代入するときに互換性のない型です」 が発生します。誰かが私が間違っているところを教えてもらえますか? 私のコードはここにあります:

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <time.h>
#ifndef RAND_MAX
#define RAND_MAX 2147483648
#endif
#define N 10

double function(double x);
double* rdm(void);

void main(void)
{
   double* Random_number_list;
   int i;
   double sum = 0.0, sum2 = 0.0, X[N+1],S, Random_number_list2[N + 1];
   double F[N+1], lower, upper, avg, avg2;
   printf("Lower Bound:  ");
   scanf("%lf", &lower);
   printf("Upper Bound:  ");
   scanf("%lf", &upper);

   Random_number_list2 = *Random_number_list;

   for (i = 0; i <= N; i++) {
      X[i] = ((upper - lower)*Random_number_list2[i]) + lower;
      F[i] = function(X[i]);
      sum = sum + F[i];
      sum2 = sum2 + (F[i] * F[i]);
   }
   avg = sum / N;
   avg2 = sum2 / N;
   S = (upper - lower) * (avg + sqrt((avg2 - (avg * avg)) / N));
   printf("The Monte Carlo approximation is %lf\n", S);  
}

double function(double x)
{
   double y;
   y = sin (x);
   return y;
}

double* rdm(void)
{
   double* Random_number_list = calloc(N + 1, sizeof(double));
   int i;

   srand(time(NULL));
   for (i = 1; i <= N; i++) {
      Random_number_list[i] = (float) rand() / (float) RAND_MAX;
   }
   return Random_number_list;
}

どうもありがとう。ジャック・メドレー

4

1 に答える 1

4

与えられた:

 int * a;
 int b[5];

次に、次のように記述できます。

 a = b;  // copying a pointer, same as a = &b[0];

ただし、次のように書くことはできません。

 b = a;  // b's memory is allocated, you cannot swap it out.

つまり、 を失い Random_number_list2、 だけで作業しますRandom_number_list

あなたがしたい:

 double* Random_number_list = rdm();

以降

 // added space, so it's clearer you're multiplying and not dereferencing.
 X[i] = ((upper - lower) * Random_number_list[i]) + lower;
于 2010-07-30T16:17:12.113 に答える