c++ - 概率计算器中的段错误

标签 c++ arrays recursion probability

我在 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] ,因此您正在运行数组的末尾并调用未定义的行为。

关于c++ - 概率计算器中的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23255944/

相关文章:

c++ - gdb 映射显示不正确的成员变量

python - 使用 Numpy 迭代列并提供给函数

arrays - Matlab all() 函数行号

java - 如何使用 LoadingCache 将递归转换为迭代?

Linux 在子目录中递归地从 .bz2 文件中搜索文本字符串

arrays - Ruby 递归中返回空数组

c++ - 非类函数可以私有(private)化吗?

c++ - 确保 C++(数字图像处理)程序和使用文件的处理程序之间的成功通信

c++ - 如果数据库可达,如何快速检查? (Qt, QML, C++)- Linux

javascript - 如何从 SharePoint 列表创建 javascript 数组?