数组与特殊压缩矩阵

一、数组的基本特性

  • 定义

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

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

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

相关推荐
地平线开发者3 分钟前
理想汽车智驾方案介绍 2|MindVLA 方案详解
算法·自动驾驶
艾莉丝努力练剑35 分钟前
【C语言16天强化训练】从基础入门到进阶:Day 7
java·c语言·学习·算法
地平线开发者1 小时前
LLM 中评价指标与训练概要介绍
算法·自动驾驶
Ghost-Face1 小时前
关于并查集
算法
ScilogyHunter1 小时前
深入理解3x3矩阵
线性代数·矩阵
flashlight_hi2 小时前
LeetCode 分类刷题:2529. 正整数和负整数的最大计数
python·算法·leetcode
花火|3 小时前
算法训练营day60 图论⑩ Bellman_ford 队列优化算法、判断负权回路、单源有限最短路
算法·图论
2501_924890523 小时前
商超场景徘徊识别误报率↓79%!陌讯多模态时序融合算法落地优化
java·大数据·人工智能·深度学习·算法·目标检测·计算机视觉
艾醒3 小时前
大模型面试题剖析:模型微调和蒸馏核心技术拆解与考点梳理
算法
艾醒4 小时前
大模型面试题剖析:微调与 RAG 技术的选用逻辑
算法