你好,我试图导出一个链接列表到一个文本文件,但不知何故,所有的时间文本文件达到非常大的大小(5gb),没有打开。
我将很高兴如果你能看到问题是什么,并给我一个方法来修复她谢谢
My code -
#include <stdio.h>
#include <stdlib.h>
typedef struct node
{
int data;
struct node *next;
} node;
node* insert(node* head, int num);
void free_list(node *head);
void fprintfList(node *head);
int main()
{
int num;
int temp;
node *head, *p;
head = NULL;
FILE * MyFile;
do
{
printf("Enter numbersn");
scanf("%d",&num);
if(num)
{
head = insert(head, num);
}
} while(num);
p = head;
MyFile = fopen("New_File.txt","w");
while(head)
{
fprintf(MyFile, "%dn",head->next);
}
//fprintfList(head);
free_list(head);
fclose(MyFile);
return 0;
}
node* insert(node* head, int num)
{
node *temp, *prev, *next;
temp = (node*)malloc(sizeof(node));
temp->data = num;
temp->next = NULL;
if(!head){
head=temp;
} else{
prev = NULL;
next = head;
while(next && next->data<=num){
prev = next;
next = next->next;
}
if(!next){
prev->next = temp;
} else{
if(prev) {
temp->next = prev->next;
prev-> next = temp;
} else {
temp->next = head;
head = temp;
}
}
}
return head;
}
void free_list(node *head)
{
node *prev = head;
node *cur = head;
while(cur)
{
prev = cur;
cur = prev->next;
free(prev);
}
}
while(head)
{
fprintf(MyFile, "%dn",head->next);
}
你的问题在这里。你循环直到head
为NULL,但从来没有真正改变head
指针,因此你只是循环永远写相同的数据,直到你用完磁盘空间。此外,您正在打印next
指针的值,而不是实际存储在节点中的数据。
首先需要打印实际数据,因此将fprintf
更改为:
fprintf(MyFile, "%dn",head->data);
其次,实际上需要遍历列表,如下所示
while(head)
{
fprintf(MyFile, "%dn",head->data);
head = head->next;
}