我想使用指向数组的指针来存储因子计算的所有中间结果。下面的代码在运行时会受到挤压。为什么以及如何修改代码以使其能够正确运行?
int factorial(int x, int *p){
if (x>1){
*p = x*factorial(x-1, p+1);
return *p;
}
else{
*p = 1;
return 1;
}
}
答案 0 :(得分:1)
用
调用它int *p = new int[10];
您的原始代码
int *p = new int(10);
表示为一个int分配空间并将其初始化为10,而不是10个元素的数组。