我面临着将数组存储在结构中的问题,这些数组进一步写入文件中。
- 数组是方阵。
- 数组和大小 n 存储在结构中。然后将该结构存储在文件(二进制文件)中。
- 该数组的大小取决于运行时用户的输入。
- 每当我将来从文件中读取结构时,我都想恢复所有按原样保存的元素(我怀疑这就是为什么将数组保存为 int **a 不起作用的原因)。
问题是矩阵的大小可以是可变的,并且取决于用户的选择(顺便说一句,也存储在结构中并进一步存储到文件中)。我承认我可以将数组的大小设置得足够大以容纳任何可能的大小值,但这会浪费空间。此外,如果我单独写入数组的每个元素,那么单独处理每个值会很麻烦。读取结构比单独读取多个值要好。当然,如果我这样做:
struct attribs
{
int a[n][n], b[n][n], n;
}
那就不行了。有更聪明的方法来解决我的问题吗?就目前而言,我将a[][]和b[][]的大小分别设置为20X20,而期望值是4X4到9X9,并将实际值存储在n中,以便在结构体时只有该部分可以轻松读取已读。
当您将结构写入文件时,其中长度取决于用户的喜好,您应该先写入大小,然后写入每个数组的内容。然后,要动态地重新创建矩阵,您只需读取大小、分配适当的内存并读取值。
如何将矩阵 a
与矩阵 b
分开取决于您,但您的示例显示它们的大小相同。这表明,在将 n×n 个整数读入 a
后,您可以开始读取 b
保存的值,假设您没有写入任何可能存在的填充字节在 a
Và b
之间(分别写入大小、a
Và b
,而不是一次写入整个结构以避免填充字节)。
如果您无法更改格式,并且这些值都作为一堆字节存储在一起,那么您必须不幸地盲目读取,存储每个值。最后一个 sizeof(int)
字节将是大小,同样假设没有填充字节。
如果可能的话,先写大小,然后写矩阵a
,然后写矩阵b
,这样可以省去很多麻烦。
当然,由于矩阵是动态调整大小的,也许您首先动态分配了一个指针数组,然后为每个指针分配了一个整数数组。在这种情况下,除非您循环遍历 a
的每个元素(a[0]
、a[1]
,...),否则您将指针写入文件而不是它们指向的值。
Tôi là một lập trình viên xuất sắc, rất giỏi!