1

我试图让自己习惯在 C++ 中使用动态数组,现在我已经第十次陷入困境。该程序编译得很好,但是在接受输入后它给出了堆栈溢出错误,并且我提供了删除构造函数中的堆的功能,我假设我有一个未启动的变量,但我真的找不到它。希望大家帮我看看。这是代码:

#include<string>
#include<cmath>
#include<sstream>
using namespace std;
#include"Calc.h"
#include<iostream>
using namespace std;

Calc::Calc(int a, int*b){
length=a;
ar=b;
AR =new int*[length];


for (int i=0; i<length;i++){
    AR[i] = new int [ar[i]]();
    }

for (int i = 0; i < length; i++)
    delete[] AR[i];
    };

Calc::~Calc(){};

int Calc::solveFor(int m0, int n0){
int ans=0;
if (m0=0) {ans =n0+1; AR[m0][n0]=ans; return n0+1;}
if (n0=0) {ans= solveFor(m0-1,1); AR[m0][n0]=ans;return ans;}
else {ans=solveFor(m0-1, solveFor(m0, n0-1));AR[m0][n0]=ans; return ans;}
};



void Calc::getSolved(){
for(int i=0; i<=length; i++){cout<<endl;
    for (int j=0; j<ar[i]; j++)
        cout<<"ACK ["<<i<<","<<j<<"]="<<AR[i][j]<<"  ";}
    cout<<endl;


};

运行.cpp:

#include<iostream>
#include<string>
#include "Calc.h"

using namespace std;

int main() {
int m;
int n;
int v[6]= {7, 7, 7, 7, 7, 7};
Calc XXX(6, v);
cin>>m;
cin>>n;


XXX.solveFor(m,n);
XXX.getSolved();

  return 0;
}

提前致谢。

4

3 回答 3

3

我可以看到的一个问题Calc::solveFor是您使用赋值运算符代替相等:

if (m0=0)

应该

if (m0==0)
于 2012-10-24T05:08:56.447 回答
1

除了上面提到的 =/== 问题之外,您似乎正在递归地计算Ackermann 函数。该函数的递归深度增长得太快,无法以这种方式进行:“A(4, 2) 不可能在任何可处理的时间内通过简单的 Ackermann 函数递归应用来计算。”

尝试使用迭代方法,或查看 memoization。

于 2012-10-24T05:13:07.463 回答
0

Ackermann 函数的值增长得非常快,因为m>3它会溢出int,您可以使用它来计算结果。这可能是无限递归的原因。

于 2012-10-24T06:43:06.053 回答