运行时错误(SIGABRT) - SPOJ

时间:2016-03-31 14:15:22

标签: c++ factorial

我的代码在代码块中运行良好但是,当我提交它时显示runtime sigabrt错误,这个错误意味着什么?

当我将指针数组的大小初始化为200时,它工作正常,但我想知道这个错误是什么?

问题的链接是:http://www.spoj.com/problems/FCTRL2/

以下是代码:

    #include <iostream>


    using namespace std;
    void multiply(int x,int *nums,int &len){
        int carry=0;
        int prod;
        for (int j=0;j<len;j++){
            prod=nums[j]*x+carry;
            carry=prod/10;
            nums[j]=prod%10;
        }
        while (carry){
            nums[len]=carry%10;
            carry=carry/10;
            len++;
        }

   }


   int main()
   {
   int t,n;

   cin>>t;
   int arr[100];
   for (int i=0;i<t;i++){
         cin>>arr[i];
   }
   for (int i=0;i<t;i++){
         n=arr[i];
         if (n==0){cout<<0<<endl;}
         else{
        int *nums= new int[0];
        nums[0]=1;
    int len=1;
    for (int i=2;i<=n;i++){
        multiply(i,nums,len);

    }


    for (int i=len-1;i>=0;i--){

        cout<<nums[i];

    }
    cout<<endl;}
}
return 0;
}

1 个答案:

答案 0 :(得分:2)

int *nums = new int[0];更改为int *nums = new int[x],其中x是数组的最大大小(取决于您在因子中预期的位数)。根据约束(1 <= n <= 100x would be 158的适当值。

int *nums = new int[n]n元素数组分配内存。