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; // 矩阵的总列数
};