我面临实现单纯形方法(或单纯形算法)的挑战。单纯形法是一种基于重建矩阵的流行线性规划算法。我的程序应该返回最佳解决方案。我在 Clion 中有一个 C++ 项目。当我运行程序时它工作正常,但在调试过程中我在其中一种方法中收到 SIGSEGV 信号(段错误)。当我尝试为矩阵分配内存时会发生这种情况。这是部分代码:
double **newTable;
newTable = new double *[rows];
for (int i = 0; i < rows; ++i) {
for (int j = 0; j < cols; ++j) {
newTable[i] = new double [cols];
}
}
我在方法结束时使用delete[]释放了内存,但它不起作用。 我已经尝试在另一个IDE(CodeBlocks)中运行该程序,但它也运行正常,但我不知道为什么会发生这种情况以及问题出现在哪里。
最佳答案
不需要这个嵌套循环。您只需要一个循环即可为这个锯齿状数组分配内存:
int main() {
int rows = 5, cols = 10;
double **newTable;
newTable = new double *[rows];
for (int i = 0; i < rows; ++i)
newTable[i] = new double[cols];
for (int i = 0; i < rows; ++i)
delete newTable[i];
delete newTable;
}
您的代码现在的方式会泄漏内存,但仅此一点不会导致段错误。您释放内存的方式也可能存在错误。
另外,由于这是 C++,我可以建议使用 std::vector
来代替吗?
#include <vector>
int main() {
std::vector<std::vector<double>> newTable(5, std::vector<double>(10));
}
关于c++ - 在 CLion 中调试时程序收到段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59070673/