|
发表于 2024-2-10 10:43:40
|
显示全部楼层
在你的代码中,`array`是一个指向常量字符串的指针,而不是一个可以重新分配内存的数组。因此,在使用`realloc`函数时会引发错误。
要解决这个问题,你需要将`array`声明为一个可修改的字符串数组,并进行动态内存分配。修改代码如下:
- #include <stdio.h>
- #include <stdlib.h>
- void shuffle(char **array, int size)
- {
- // 这里是洗牌函数的代码
- }
- int main(void)
- {
- char *array[] = {"a", "b", "c", "d"}; // 修改为字符串数组
- int size = sizeof(array) / sizeof(array[0]);
- shuffle(array, size);
- for (int i = 0; i < size; i++)
- {
- printf("%s", array[i]);
- }
- printf("\n");
- char **array2 = NULL;
- int size2 = size * 2;
- array2 = (char **)realloc(array, size2 * sizeof(char *)); // 动态分配内存
- // 这里没有必要用循环来赋值,可以直接使用 array2 = array
- // for (int i = 0; i < size * 2; i++)
- // {
- // array2[i] = array[i];
- // }
- for (int i = 0; i < size2; i++)
- {
- printf("%s", array2[i]);
- }
- free(array2); // 释放动态分配的内存
- return 0;
- }
复制代码
在上述代码中,我们将`array`从指向常量字符串的指针更改为字符串数组。然后,在调用`realloc`函数时,我们将数组的长度乘以`sizeof(char *)`来分配内存。最后,记得在程序结束前使用`free`函数释放动态分配的内存。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 |
|