我怎样才能摆脱分段错误?

How can I get rid of segmentation error?

我的目标是找到(p个连续数的最小值)*p的最大值。这里 1<=p<=N 和 1<=N<=100000 和 1<=number<=1000000.I 已经部分解决了 problem.But 在某些情况下我得到这个运行时错误。

" 在抛出 'std::bad_alloc' 的实例后调用终止 什么():std::bad_alloc 此应用程序已请求运行时以异常方式终止它。 请联系应用程序的支持团队以获取更多信息。"

我发现错误是因为程序试图访问不允许的内存。但是我不知道哪部分代码正在尝试访问未分配的 memory.Please 帮助我。

#include <iostream>

using namespace std;

int main(){
int N=0;
cin>>N;
int **A,*B,i,j,num;
A = new int*[N];
for(i=0;i<N;i++)
    A[i] = new int[N]();
B = new int[N]();

for(i=0;i<N;i++){
    cin>>num;
    A[0][B[0]] = num;
    for(j=0;j<B[0];j++){
        A[j+1][B[j+1]] = min(A[j][B[j+1]],A[j][B[j+1]+1]);
        B[j+1]++;
    }
    B[0]++;
}
long long maxim = 0;
for(i=0;i<N;i++){
   for(j=0;j<B[i];j++){
      if(A[i][j]*(i+1) > maxim)
        maxim = A[i][j]*(i+1);
   }
}

cout<<maxim;
delete []A;
delete []B;
return 0;
}

std::bad_alloc 在 failing to allocate memory.

时抛出

您正在尝试为 100000 * 100000 个整数分配 space。那是大约 40GB 的 RAM,您可能没有。

成为软件工程师的一部分是学习将问题分解成更小的块。要解决这个问题,你应该从把问题分解到最小的单位开始。

int main()
{
    size_t dimension = 100000;
    int** outer = new int[dimension];
    for (size_t i = 0; i < dimension; ++i) {
        outer[i] = new int[dimension];
    }
}

编译并加载到调试器中,逐步查找异常发生的位置。或者你可以这样写:

#include <iostream>

int main()
{
    size_t dimension = 100000;
    size_t allocated = 0;
    int** outer = new int*[dimension];
    allocated += sizeof(int*) * dimension;
    for (size_t i = 0; i < dimension; ++i) {
        try {
            outer[i] = new int[dimension];
            allocated += sizeof(int) * dimension;
        } catch (std::bad_alloc&) {
            std::cerr << "bad alloc at iteration " << i << " with " << allocated << " bytes allocated\n";
            return -1;
        }
    }
}

或者

#include <iostream>

int main()
{
    size_t dimension = 100000;
    std::cout << "Allocating outer: " << (dimension * sizeof(int*)) << " bytes\n";
    int** outer = new int[dimension];
    for (size_t i = 0; i < dimension; ++i) {
        std::cout << "Allocating outer[" << i << "] (" << (dimension * sizeof(int)) << " bytes\n";
        outer[i] = new int[dimension];
    }
}