c - 在代数符号中为上三角矩阵分配空间

标签 c matrix malloc free algebra

我正在从事一个涉及矩阵分解的项目(用 C 语言编写),我需要一些帮助。 我的目标是为上三角矩阵分配内存,我想通过代数行和列表示法访问它(即 {1,2,...,n} 中的 i,j 而不是 i ,j 在 {0,1,...,n-1} 中)。 例如,在 5x5 矩阵中,如果我输入 matrix[3][4],我应该能够访问 [3][4] 元素。

我的非代数索引上三角矩阵代码如下所示:

double** malloc_sup_matrix (int n)
{
    double**    L;
    int         i;

    L = (double**)malloc((n)*sizeof(double*));

    if(L == NULL)
        printerror("allocating space for the matrix (rows).");        

    for(i = 0;  i < n;  i++)
    {
        L[i] = (double*)malloc((n-i)*sizeof(double));
        if(L[i] == NULL)
            printerror("allocating space for the matrix (cols).");
        L[i]-=i;
    }
    return L;
}

我的代数索引一的代码(我还没有检查分配的空间是否为空,我会在我停止乱搞这个的时候再做):

    int**   m;
    int     i, n;

    n = 10;

    m = (int**)malloc((n+1)*sizeof(int*));
    for(i = 0; i < n; i++)
    {
        m[i] = (int*)calloc((n+1)-(i),sizeof(int));
        m[i] -= i;
    }

    m--;
    for(i = 0; i < n; i++)
    {
        m[i]--;
    }

它按照我想要的方式工作,但是我在释放我使用的空间时遇到了问题。这是我正在做的方式:

    for(i = 1; i <= n; i++)
    {
        m[i]++;
    }    

    for(i = 0; i < n; i++)
    {
        m[i] += (i);
        free(m[i]);
    }
    m++;
    free(m);

你们有什么建议吗?非常感谢你 ^^。

最佳答案

这条线路有问题:

m--;
for(i = 0; i < n; i++)
{
    m[i]--;
}

你正在递减 m,但然后继续从 0 开始索引它......我猜你最终可能会搞乱堆结构。

我设法让你的代码 valgrind 像这样没有错误:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>


int main(int argc, char *argv[])
{
    int**   m;
    int     i, j, n;

    n = 10;

    m = (int**)malloc((n+1)*sizeof(int*));
    for(i = 0; i < n; i++)
    {
        m[i] = (int*)calloc((n+1)-(i), sizeof(int));
        m[i] -= i;
    }

    for(i = 0; i < n; i++)
    {
        m[i]--;
    }

    m--;

    /* Access it like m[1][1] ... m[n][n], m[i][j] (with i <= j) */

    /*
    for (i = 1; i <= n; i++) {
        for (j = i; j <= n; j++) {
            m[i][j] = i+j;
        }
    }
    */

    m++;

    for(i = 0; i < n; i++)
    {
        m[i]++;
    }

    for(i = 0; i < n; i++)
    {
        m[i] += (i);
        free(m[i]);
    }

    free(m);

    return 0;
}

关于c - 在代数符号中为上三角矩阵分配空间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29864471/

相关文章:

c - UDP - 多服务器单客户端

c++ - 如何在 C++ boost ublas 中将文件流式传输到矩阵中?

python - 使用滚动,俯仰和偏航使图像变形

c - 使用 malloc 时 C 中的奇怪段错误

c - 为什么用 malloc 初始化的指针是空指针?

c - 尝试读取隐藏文件 linux 时出现段错误

c - 如何为我的 C 结构数组分配更多空间?

c - Unix(FreeBSD) - 如何获取每秒的真实时钟

无法使用 atoi() 将 char 数字转换为 int

performance - 在Matlab中获取每个子矩阵n列与新矩阵中的列一样长