用c语言写一段代码,将单链表以头文件形式保存
时间: 2024-10-08 14:13:22 浏览: 40
C语言版本 单链表实现,亲测可用
在C语言中,我们可以使用结构体和函数来表示和操作链表,并将其转换成头文件的形式。这里是一个简单的例子,我们将创建一个`ListNode`结构体表示链表节点,然后编写一个函数`saveLinkedListToFile`来序列化链表到头文件。
首先,定义链表节点结构:
```c
typedef struct ListNode {
int data;
struct ListNode* next;
} ListNode;
```
接着,定义一个用于保存链表的函数:
```c
#include <stdio.h>
#include <stdlib.h>
// 函数声明 - 在头文件中会看到这个
void saveLinkedListToFile(ListNode** head, const char* filename);
// 用于将链表保存到文件的私有实现
void _saveListNodeToFile(ListNode* node, FILE* file) {
if (node != NULL) {
fprintf(file, "%d ", node->data);
_saveListNodeToFile(node->next, file);
}
}
// 使用示例
void saveLinkedListToFile(ListNode** head, const char* filename) {
FILE* file = fopen(filename, "w");
if (file == NULL) {
printf("Failed to open file.\n");
return;
}
_saveListNodeToFile(*head, file);
fclose(file);
}
```
要在头文件中包含上述代码,可以创建`linkedList.h`:
```c
#ifndef LINKED_LIST_H
#define LINKED_LIST_H
typedef struct ListNode {
int data;
struct ListNode* next;
} ListNode;
void saveLinkedListToFile(ListNode** head, const char* filename); // 函数声明
#endif // LINKED_LIST_H
```
现在你可以使用`saveLinkedListToFile`函数将链表保存到头文件中,例如:
```c
int main() {
// 初始化链表...
saveLinkedListToFile(&head, "linked_list.txt");
return 0;
}
```
阅读全文