我想使用指向数组的指针来存储阶乘计算的所有中间结果。下面的代码在运行时会崩溃。为什么以及如何修改代码以使其能够正常运行?
int factorial(int x, int *p){
if (x>1){
*p = x*factorial(x-1, p+1);
return *p;
}
else{
*p = 1;
return 1;
}
}
用
int *p = new int[10];
您的原始代码
int *p = new int(10);
意味着为单个 int 分配空间并将其初始化为 10,而不是 10 元素数组。