c++ - 返回未定义行为的递归行列式函数

标签 c++ recursion linear-algebra determinants

我编写了一个用于计算行列式的递归函数。我知道我可以更有效地完成它,但这不是这里的重点。我有一个名为“det1”的变量,它保存递归结束时行列式的最终值。 奇怪的是,当我在 det 函数中返回这个值时,我得到了完全的垃圾。但是,当我简单地简单地打印出“det1”时,我得到了答案。这里有什么猜测吗?

int det1 = 0;
int p = 0; 

int det(vector<vector<int> > (&A)){
    if (A.size() != A[0].size()){
        cout << "Determinant Error: non-square matrix. \n";
        return 0; 
    }
    int cF; 
    vector<vector<int> > temp01;
    if (A.size() == 2){
        det1 += (A[0][0]*A[1][1]-A[0][1]*A[1][0]); 
        //cout << "Determinant : " << det1 << "\n";
        int output = det1;                     ///////////////////////////////////////Problem with final return 
        //cout << "Recursion Count : " << p << "\n";  
        //return(output);                        ///////////////////////////////////////
    }else{//extract until a 2x2 is reached
        for (int i = 0; i < A.size(); i++){
             temp01 = extractNext(A,0, i); 
             //printMatrix(temp01); 
             cF = pow(-1, (0)+(i))*A[0][i]; 
             //cout << "Cofactor : " << cF << "\n"; 
             for (int j = 0; j< temp01.size(); j++){
                 temp01[0][j] = cF*temp01[0][j]; //account for cofactor by multiplying it in
             }
             //printMatrix(temp); cout << "\n";
             p++;  
             det(temp01); 
        }
    } 
}

最佳答案

您不会在所有代码路径上返回一个值,当您使用一个从未存在过的返回值时,这最终会导致未定义的行为。
(一个相当现代的编译器应该警告你这一点。)

您应该从递归中返回行列式而不是改变全局 - 混合可变状态和递归通常只会导致麻烦。
(这也使您的代码更类似于行列式的数学定义,这反过来又使其更容易理解和验证。)

有一些小的改动,我会建议类似

int det(const vector<vector<int>> &A)
{
    if (A.size() != A[0].size()){
        cout << "Determinant Error: non-square matrix. \n";
        return 0; 
    }

    if (A.size() == 2)
    {
        return A[0][0] * A[1][1] - A[0][1] * A[1][0]; 
    }
    else
    {
        int determinant = 0;
        int sign = -1;
        for (int i = 0; i < A.size(); i++){
            vector<vector<int>> submatrix = extractNext(A, 0, i);
            sign = -sign;
            int cofactor = sign * A[0][i]; 
            for (int j = 0; j < submatrix.size(); j++){
                submatrix[0][j] = cofactor * submatrix[0][j];
            }
            determinant += det(submatrix);
        }
        return determinant;
    } 
}

关于c++ - 返回未定义行为的递归行列式函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52159613/

相关文章:

c++ - 动态数组更改内存地址位置

c++ - ARM 平台的数据转换(来自 x86/x64)

c++ - 当内存分配数不总是相同时如何检测内存泄漏?

javascript - 递归搜索和JavaScript中的对象

java - 为什么我会收到 Stackoverflow 错误?

python - 为什么我不能用单列矩阵替换 NumPy 数组中的列?

c++ - 使用 C++ Boost 库有哪些优势?

Python-递归-编程新手

python - 如何有效地(就地)乘以不同大小的 memmaped numpy 数组的两个 View

python - 在 Python 中求解线性整数方程组