在你的代码中,`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 小助理,如未能正确解答您的问题,请继续追问。 |