数据结构绪论相关概念复习笔记

1.广义表是什么?

【1】列表的列表,允许列表中包含其他列表,从而形成一个嵌套结构。

【2】非线性结构,类似线性结构,但是因为可以嵌套其他列表所以更类似于一个图或者树形结构。

【3】广义表的例子:[1,2,3,[4,5],6,7],这里的1,2,3,6,7是平级,但是[4,5]又是一个列表。

2.什么叫稀疏矩阵?

【1】一种矩阵,非零元素相对于零元素来说非常少的矩阵。

【2】稀疏矩阵例子:如下图所示,矩阵中除了3,5,7均是0,0元素比非0元素多,故为稀疏矩阵。

【2】为了有效地存储和处理稀疏矩阵,通常不会直接存储所有的零。在C语言中,由于没有内置的高级数据结构来直接表示稀疏矩阵,通常需要程序员自己设计合适的数据结构来存储和操作稀疏矩阵。

[1]三元组列表表示:

// 定义一个结构体,用来存储稀疏矩阵中的一个非零元素的信息
struct Triplet {
    int row;    // 非零元素所在的行索引
    int col;    // 非零元素所在的列索引
    double value;// 非零元素的值,使用double类型以支持小数和较大的数值范围
};

// 定义一个结构体,用来存储整个稀疏矩阵的三元组列表
struct TripletList {
    struct Triplet* triplets; // 指向一个数组的指针,该数组包含所有的Triplet结构体实例
    int size;                 // 当前存储的非零元素数量
    int capacity;             // 为三元组数组分配的总容量,用于优化性能,避免频繁重新分配内存
};

[2]压缩列存储表示:

// 定义一个结构体,用来使用CCS方法存储稀疏矩阵
struct CCS {
    double* values;     // 一个数组,存储矩阵中所有非零元素的值
    int* row_indices;   // 一个数组,存储每个非零元素的行索引
    int* col_pointers;  // 一个数组,存储每列非零元素在values和row_indices数组中的起始位置
    int num_rows;       // 矩阵的行数
    int num_cols;       // 矩阵的列数
    int num_nonzeros;   // 矩阵中非零元素的总数
};

[3]压缩列存储表示:

// 定义一个结构体,用来使用CCS方法存储稀疏矩阵
struct CCS {
    double* values;     // 一个数组,存储矩阵中所有非零元素的值
    int* row_indices;   // 一个数组,存储每个非零元素的行索引
    int* col_pointers;  // 一个数组,存储每列非零元素在values和row_indices数组中的起始位置
    int num_rows;       // 矩阵的行数
    int num_cols;       // 矩阵的列数
    int num_nonzeros;   // 矩阵中非零元素的总数
};

[4]块稀疏矩阵表示:

// 定义一个结构体,用来表示稀疏矩阵中的一个块
struct Block {
    int row_start; // 块在行方向的起始索引
    int col_start; // 块在列方向的起始索引
    double* data;  // 指向存储块中所有元素的数组的指针
    int block_rows; // 块的行数
    int block_cols; // 块的列数
};

// 定义一个结构体,用来使用块稀疏矩阵方法存储整个稀疏矩阵
struct BlockSparseMatrix {
    struct Block* blocks; // 指向一个数组的指针,该数组包含所有的Block结构体实例
    int num_blocks;       // 矩阵中块的总数
    int num_rows;         // 矩阵的总行数
    int num_cols;         // 矩阵的总列数
};

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是lethe先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值