我正在进行一项任务,我必须编写一个函数,它接受一个动态分配的字符串数组和一个索引,并删除该索引处的元素。使用提供的示例main函数来测试代码,它在函数的第一次调用时崩溃,我不知道为什么。这是我的代码。
int removeElement(ArrayList *list, int index)
{
int i;
if(list != NULL && index < list->size)
{
for(i = index; i < list->size - 1; i++)
{
free(list->array[i]);
list->array[i] = malloc(sizeof(char) * (strlen(list->array[i + 1]) + 1));
if(list->array[i] = NULL)
{
printf("Can't allocate memory. Returning 0.\n");
return 0;
}
strcpy(list->array[i], list->array[i + 1]);
}
free(list->array[i]);
list->array[i] = NULL;
list->size--;
return 1;
}
return 0;
};
我认为这可能是因为第一个字符串(“名称列表”)大于第二个字符串(“Sean”)。但我仍然对它是如何工作感到困惑。
答案 0 :(得分:1)
这不是您问题的直接答案,但您也可以只复制指针而不是所有这些malloc
和strcpy
:
int i;
if (list != NULL && index < list->size)
{
free(list->array[index]);
for (i=index; i<list->size-1; i++)
list->array[i] = list->array[i+1];
list->size--;
return 1;
}
或者如果你不介意字符串的顺序,那就更好了:
if (list != NULL && index < list->size)
{
free(list->array[index]);
if (index < list->size-1)
list->array[index] = list->array[list->size-1];
list->size--;
return 1;
}