把结构体链表保存到二进制文件中并读取

把结构体链表保存到二进制文件中并读取

第一次发表文章,不足还请见谅

#include<stdio.h>
#include<stdlib.h>
#define max 20
int main(){

	FILE *fp;     //定义文件指针
	char ch[max]; 
	int s;
	fp=fopen("C:\\Users\\ASUS\\Desktop\\二进制文件.data","ab+");  
	//以可读写形式打开文件,通过文件属性找到绝对路径,然后把'\'换成'\\'或者把'\'换成'/'
	typedef struct data{       //定义结构体
		int age;
		char name[max];
		struct data *next;
	}link;
	link *head,*node,*end,*L;      //定义头节点,当前节点,尾节点,备用节点
	head=(link*)malloc(sizeof(link));       //为头结点分配空间
	end=head;                      //如果未给头结点分配空间,则end为NULL
	
	if(head==NULL)           //判断节点是否创建成功
	{
		printf("节点创建失败");
		exit(1);
	}
	printf("请输入s的值,1.输入信息 0.停止输入\n");    
	scanf("%d",&s);
	while(s){                        //判断是否输入信息
		node=(link*)malloc(sizeof(link));      //申请节点存储信息
		printf("请输入年纪和名字\n");
		scanf("%d",&node->age);              
  //对于结构体指针用node->age访问信息,对于结构体变量用 变量名.age访问
		scanf("%s",node->name);
		end->next=node;          //将节点接到尾节点后面
		end=node;                
		printf("请输入s的值,1.输入信息 0.停止输入\n");//是否继续输入信息
		scanf("%d",&s);
	}
	end->next=NULL;   //将尾节点的下一个节点赋值为NULL(空指针)

	L=head;       //将头结点赋值给L
	while(L->next!=NULL){    //输出结构体链表信息
		printf("%d %s\n",L->next->age,L->next->name);
		L=L->next;
	}
	L=head;            
	while(L->next!=NULL){      //将结构体信息写入二进制文件
		fwrite(L->next,sizeof(link),1,fp);
		L=L->next;
        printf("写入成功!");
	}
	rewind(fp);     //将文件指针定位到文件头
	while(!feof(fp)){      //输出二进制文件全部信息
		fread(L,sizeof(link),1,fp);
		printf("%d %s\n",L->age,L->name);
	}
	fclose(fp);   //关闭文件
	return 0;
}
  • 5
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
为了将二进制文件读入链表,你可以按照以下步骤进行操作: 1. 首先,你需要定义一个结构体来表示学生的信息,包括学号、姓名、性别、年龄和成绩等字段。 2. 然后,你需要创建一个链表结构,用来存储学生的信息。链表的每个节点都包含一个学生的结构体对象和指向下一个节点的指针。 3. 接下来,你需要打开二进制文件,以读取数据。你可以使用C语言的fopen函数打开文件,使用fread函数读取文件数据,并使用fclose函数关闭文件。 4. 在读取文件数据之前,你需要判断文件是否存在,如果不存在则创建一个空链表。如果文件已经存在,则需要将文件数据读取链表。 5. 当你读取文件的学生信息后,需要将其插入到链表的合适位置,按照总成绩从大到小的顺序进行插入。你可以通过比较当前学生的成绩与链表已有学生的成绩来确定插入位置。 6. 最后,你可以选择是否继续从用户输入读取更多的学生信息,如果用户选择继续,则重复步骤3-5,直到用户选择退出。 7. 当用户选择退出后,你可以将链表数据重新写入到二进制文件。你可以使用fwrite函数将链表数据按照总成绩从大到小的顺序写入到文件。 请注意,这只是一个概述,并不包含具体的代码实现。实际的代码可能需要进一步的细节处理和错误处理。同时,你还可以根据具体需求对代码进行修改和优化。希望对你有所帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [实验十 学生成绩管理(二进制文件读写)byHNU信息院2020小毕](https://blog.csdn.net/jiajia1as/article/details/111879722)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [高级java开发集合问题](https://download.csdn.net/download/tgh5330992/88227020)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无·极

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值