gpt4 book ai didi

c - 如何重新分配不同大小的二维结构指针

转载 作者:太空宇宙 更新时间:2023-11-04 07:48:04 25 4
gpt4 key购买 nike

我想重新分配二维指针数组。必须是动态的如下ascii

+=====+==============+==============+==============+==============+======+
| | [0] | [1] | [2] | [3] | [..] |
+=====+==============+==============+==============+==============+======+
| [0] | 'a' | 'b' | 'c' | 'd' | |
+-----+--------------+--------------+--------------+--------------+------+
| [1] | object[0][0] | object[1][0] | object[2][0] | object[3][0] | |
+-----+--------------+--------------+--------------+--------------+------+
| [2] | object[0][1] | object[1][1] | object[2][1] | object[3][1] | |
+-----+--------------+--------------+--------------+--------------+------+
| [3] | object[0][2] | object[1][2] | object[2][2] | | |
+-----+--------------+--------------+--------------+--------------+------+
| [4] | object[0][3] | | object[2][3] | | |
+-----+--------------+--------------+--------------+--------------+------+
| [5] | object[0][4] | | | | |
+-----+--------------+--------------+--------------+--------------+------+
| [6] | object[0][5] | | | | |
+-----+--------------+--------------+--------------+--------------+------+

在此表中,每个列的大小都不同。我怎样才能用 2d 结构做到这一点。我用 malloc 分配了矩阵。但我想重新分配第二个索引。像这个矩阵[25][n]。 N 必须为每个具有不同大小的列重新分配。但它必须在运行时

代码:

#include <stdio.h>
#include <stdlib.h>

typedef struct{
char word[20];
}Dictionary;

Dictionary **object;
void initializeDictionary()
{
// Create matrix [29][1]
object=(Dictionary**)malloc(29 * sizeof(Dictionary*));
object[0]=(Dictionary*)malloc(1*sizeof(Dictionary));
}

最佳答案

有了指针,这是自然而然的。在您的代码中,您有一个 Dictionary**,它确实是指向 Dictionary 的指针。但是您可以看到它是一个 Dictionary* 数组,其中每个指针指向不同大小的 Dictionary 对象数组。

Dictionary** objects;
const int COLUMNS = 29;

objects = malloc(COLUMNS * sizeof(Dictionary*));

objects[0] = malloc(2 * sizeof(Dictionary)); // first column 2 elements
objects[1] = malloc(3 * sizeof(Dictionary)); // second column 3 elements

// ...

for (int i = 0; i < COLUMNS; ++i)
free(objects[i]);

free(objects);

关于c - 如何重新分配不同大小的二维结构指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55679024/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com