繁体   English   中英

概率计算器中的细分错误

[英]Segmentation Fault In Probability Calculator

我正在linux上编译它。 它将编译并运行,但是当我输入n和p的值时,这就是我的终端的样子:

7 1.0分段故障(核心已转储)

在这种情况下,7是n的输入,而1.0是p的输入。 我尝试了不同的值。 这个想法是使用动态编程通过递归来填充二维概率数组。 让我知道您是否需要更多信息,但这只是整个代码。

#include <iostream>
using namespace std;

int main(int argc, char *argv[])
{

  int n;
  double p;

  cin >> n;
  cin >> p;

  cout << n;
  cout << p;

  cout << "Initializing array.";
  double** probability = new double*[n];
  for(int i = 0; i < n; ++i)
  {
     probability[i] = new double[n];
  }

  //cout << "Beginning filling i loop.";
  for(int i = 0; i < n; i++)
  {
     probability[i][0] = 0;
  }
  //cout << "Beginning filling j loop.";

  for(int j = 0; j < n; j++)
  {
     probability[0][j] = 1;
  }

  //cout << "Beginning filling nested loop.";
  for(int i = 1; i< n; i++)
  {
     for(int j = 1; j< n; j++)
     {
        probability[i][j] = (p * probability[i-1][j]) + ((1-p) * probability[i][j-1]);
     }
  }

  cout << "Probability: ";
  cout << probability[n][n];

  //cleanup
  for(int i = 0; i < n; ++i)
  {
    delete probability[i] ;
  }
  delete probability;

  return 0;
}
cout << probability[n][n];

probability[][]是一个n×n数组。 最后一个元素是probability[n-1][n-1] ,因此您正在运行数组的末尾并调用未定义的行为。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM