数组与特殊压缩矩阵

一、数组的基本特性

  • 定义

    cpp 复制代码
    int arr[3][3]; // 3x3二维数组
  • 存储方式

    • 行优先存储(C语言默认):元素按行连续存储。

    • 列优先存储:需手动实现(如科学计算中的Fortran风格)。

  • 访问元素

cpp 复制代码
arr[i][j] = value; // 直接访问

二、 特殊矩阵的压缩存储

针对特定规律的矩阵(如对称、稀疏),可通过压缩存储减少空间占用。

(1) 对称矩阵

  • 特点a[i][j] = a[j][i],只需存储上三角下三角

  • 压缩存储

    • 将下三角元素存入一维数组,元素总数:n(n+1)/2

    • 下标转换公式(行优先):

      • i ≥ j 时,一维数组索引 k = i*(i+1)/2 + j

      • i < j 时,交换 ij

示例代码

cpp 复制代码
// 压缩对称矩阵
int compressSymmetric(int matrix[][N], int n, int compressed[]) {
    int k = 0;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j <= i; j++) { // 存储下三角
            compressed[k++] = matrix[i][j];
        }
    }
    return k; // 返回压缩后长度
}

// 访问压缩后的元素
int getElement(int compressed[], int i, int j) {
    if (i < j) { // 上三角转下三角
        int temp = i;
        i = j;
        j = temp;
    }
    return compressed[i*(i+1)/2 + j];
}

(2) 三角矩阵

  • 上三角矩阵:只存储主对角线及以上元素。

  • 下三角矩阵:只存储主对角线及以下元素。

  • 压缩存储:类似对称矩阵,但需额外存储剩余部分的常量(如0)。

示例代码(下三角矩阵):

cpp 复制代码
// 压缩下三角矩阵(包含对角线)
void compressLowerTriangular(int matrix[][N], int n, int compressed[]) {
    int k = 0;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j <= i; j++) {
            compressed[k++] = matrix[i][j];
        }
    }
}

(3) 稀疏矩阵

  • 特点:绝大多数元素为0,通过压缩存储非零元素。

  • 存储方式

    1. 三元组表示法:存储非零元素的行、列、值。

    2. 十字链表:适合频繁插入/删除操作(如图像处理)。

三元组表示法示例

cpp 复制代码
typedef struct {
    int row, col, value;
} Triple;

// 压缩稀疏矩阵
void compressSparse(int matrix[][M], int rows, int cols, Triple compressed[]) {
    int k = 0;
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            if (matrix[i][j] != 0) {
                compressed[k].row = i;
                compressed[k].col = j;
                compressed[k].value = matrix[i][j];
                k++;
            }
        }
    }
}

// 访问稀疏矩阵元素
int getSparseElement(Triple compressed[], int size, int i, int j) {
    for (int k = 0; k < size; k++) {
        if (compressed[k].row == i && compressed[k].col == j) {
            return compressed[k].value;
        }
    }
    return 0; // 未找到则返回0
}

三、对比与选择

四、操作复杂度

  • 普通数组

    • 访问:O(1)

    • 插入/删除:不适用(需重构数组)

  • 压缩存储矩阵

    • 访问:O(1)(对称/三角)或 O(non_zero)(稀疏矩阵遍历)

    • 插入/删除:仅稀疏矩阵支持高效操作(如十字链表)

五、实际应用

  • 图像处理:稀疏矩阵存储图像的非零像素。

  • 科学计算:对称矩阵用于物理模拟中的刚度矩阵。

  • 机器学习:三角矩阵用于LU分解加速计算。

六、总结

在C语言中,数组是基础数据结构,而特殊矩阵通过压缩存储可显著优化空间和操作效率。根据矩阵特性和应用场景选择合适的存储方式:

  • 对称/三角矩阵:用一维数组压缩存储。

  • 稀疏矩阵:用三元组或十字链表实现动态操作。

相关推荐
报错小能手1 分钟前
数据结构 b树(b-树)概念详解
数据结构·b树
报错小能手13 分钟前
数据结构 b+树
数据结构·b树·算法
元亓亓亓24 分钟前
LeetCode热题100--64. 最小路径和--中等
算法·leetcode·职场和发展
mit6.82428 分钟前
回溯+位运算|前缀和优化背包
算法
努力学算法的蒟蒻39 分钟前
day49(12.30)——leetcode面试经典150
算法·leetcode·面试
天赐学c语言40 分钟前
12.30 - 合并区间 && C++中class和C语言中struct的区别
c语言·c++·算法·leecode
报错小能手1 小时前
数据结构 b树(b-)树
数据结构·b树
有一个好名字1 小时前
力扣-递增的三元子序列
算法·leetcode·职场和发展
陌路201 小时前
S31 B树详解
数据结构·b树
Boop_wu1 小时前
[Java 数据结构] 图(1)
数据结构·算法