本关任务:编写一个函数实现顺序表的销毁。如果线性表 L 存在,该操作释放线性表的空间,使线性表成为未初始化状态,返回 OK;否则对于一个未初始的线性表,是不能进行销毁操作的,返回 INFEASIBLE。
时间: 2024-09-24 12:05:07 浏览: 38
本关任务是让你编写一个函数,用于清除顺序表(也称为线性表或数组列表)的数据,并释放它所占用的内存空间,使其恢复到未初始化的状态。这个函数在成功完成销毁操作后会返回"OK",表示操作成功。如果尝试销毁的是一个从未初始化过的顺序表,函数则应返回"Infeasible",因为这样的操作是没有意义的。
这是一个基础的伪代码示例,假设我们有一个包含`size`元素的`Node`结构体作为顺序表:
```c
// 假设 Node 是顺序表节点的结构体
typedef struct Node {
void* data;
struct Node* next;
} List;
void destroySequentialList(List** head) {
if (*head == NULL) { // 判断是否为空指针
printf("Infeasible: Trying to destroy an uninitialized list.\n");
return;
}
List* current = *head; // 初始化当前节点为头结点
while (current != NULL) {
free(current->data); // 释放每个节点的数据部分
current = current->next; // 移动到下一个节点
}
*head = NULL; // 清空头指针
printf("OK: Sequence list destroyed successfully.\n");
}
```
阅读全文