问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

画出fat表达文件分配的链表和空闲链表

发布网友 发布时间:2022-04-27 07:32

我来回答

1个回答

热心网友 时间:2022-06-28 14:06

这是我最开始学习链表的时候写的一个很小的程序,好像不是很完善,但是大致应该没有问题,你可以参照的看看。太晚了,实在是不想写了。
#include <stdio.h>
#include <io.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 200

struct student
{
char no[10]; // 学号
char name[50]; // 姓名
float score[3]; // 分数
float math;
float eng;
float phy;
};
struct data
{
int count; // 当前学生数组中学生的个数
struct student stu[MAX]; // 学生数组
}dd;

// 显示主菜单
void menu()
{
system("cls");//清屏
printf("\n\n\n");
printf("\t\t\t *******************************\n");
printf("\t\t\t \n");
printf("\t\t\t 学生成绩管理系统 \n");
printf("\t\t\t \n");
printf("\t\t\t [1] 查看所有学生信息 \n");
printf("\t\t\t [2] 输入学生记录 \n");
printf("\t\t\t [3] 删除学生记录 \n");
printf("\t\t\t [4] 修改学生记录 \n");
printf("\t\t\t [5] 查询学生成绩(学号) \n");
printf("\t\t\t [6] 查询成学生绩(姓名) \n");
printf("\t\t\t [7] 查看成绩排序(学号) \n");
printf("\t\t\t [0] 退出 \n");
printf("\t\t\t \n");
}

// 等待用户按回车后回到主菜单
void to_menu()
{
char c1,c2;
printf("\n\n\n按回车键返回主菜单...");
scanf("%c%c",&c1,&c2);//第一个字符吸收上次的确认回车键
menu();
}
//统计信息
void ren()
{
int A=0,B=0,C=0,D=0,E=0,s;
int i;

for(i=0;i<dd.count;i++)
{
s=(int)(dd.stu[i].math/10);
switch(s)
{
case 10:
case 9:
A++;
break;
case 8:
B++;
break;
case 7:
C++;
break;
case 6:
D++;
break;
default :
E++;
break;
}
}

printf("总人数:%d\n",dd.count);
printf("获得“优秀”的人数:%d\n",A);
printf("获得“良”的人数:%d\n",B);
printf("获得“中”的人数:%d\n",C);
printf("获得“及格”的人数:%d\n",D);
printf("不及格的人数:%d\n",E);

}

// 查看所有学生信息
void view_data()
{
int i;
printf("学号\t姓名\t数学\t英语\t物理");
printf("\n-------------------------------------------------------------------\n");
for(i=0;i<dd.count;i++)
printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
printf("\n-------------------------------------------------------------------\n");
ren();
}

// 将数据从结构体数组保存到文件中
void save_data()
{
FILE *fp;//文件指针
int i,k;
k = dd.count;//其实k没有什么实际的意义,直接在fwrite里使用&dd.count就可以了。
fp=fopen("D:\\data.txt","w");//文件存储位置:当前文件夹
fwrite(&k,sizeof(int),1,fp);
for(i=0;i<dd.count;i++)
fwrite(&dd.stu[i],sizeof(struct student),1,fp);
fclose(fp);
}

// 输入学生记录
void add_data()
{
int b;
int k = dd.count;
while(k<MAX)
{
printf("请输入学生学号:"); scanf("%s",dd.stu[k].no);
printf("请输入学生姓名:"); scanf("%s",dd.stu[k].name);
printf("请输入数学成绩:"); scanf("%f",&dd.stu[k].math);
printf("请输入英语成绩:"); scanf("%f",&dd.stu[k].eng);
printf("请输入物理成绩:"); scanf("%f",&dd.stu[k].phy);

dd.count++;//需要提前置0,在主函数中。
k = dd.count;
printf("\n\n继续添加学生信息[1-yes 0-no]:");
scanf("%d",&b);
if(b==0) break;
}
save_data();
}

// 将数据从文件读到结构体数组中
void read_data()
{
FILE *fp;
int i,k;

k=0;
if((fp=fopen("D:\\data.txt","r"))==NULL) // 如果文件不存在
{
dd.count = 0;
}
else
{
fread(&k,sizeof(int),1,fp);
dd.count = k;
for(i=0;i<k;i++)
{
fread(&dd.stu[i],sizeof(struct student),1,fp);
}
fclose(fp);
}
}

// 删除学生记录
void delete_data()
{
int i,k;
char no[10];
printf("\n请输入要删除学生的学号:");
scanf("%s",no);
k = -1;
for(i=0;i<dd.count;i++)
{
if(strcmp(dd.stu[i].no,no)==0)
{
k = i;
break;
}
}
if(k==-1)
{
printf("\n\n没有找到该学生(学号-%s)!",no);
}
else
{
//你没有写删除的操作啊
for(i=k; i<dd.count-1; i++)//将后面的数据前移一位
dd.stu[i] = dd.stu[i+1];
memset(&dd.stu[dd.count-1],0,sizeof(struct student));//将dd.stu[dd.count-1]数据置0
dd.count--;

save_data();
printf("\n\n删除学生(学号-%s)记录成功!",no);
}
}

// 修改学生记录
void edit_data()
{
int i,k;
char no[10],name[50];
printf("\n请输入要修改学生的学号:");
scanf("%s",no);
k=-1;
for(i=0;i<dd.count;i++)
{
if(strcmp(dd.stu[i].no,no)==0)
{
k=i;
break;
}
}
if(k==-1)
{
printf("\n\n没有找到该学生(学号-%s)!",no);
}
else
{
printf("\n请输入学生数据:");
printf("\n姓名");
printf("\n--------------------------------------------------------------------\n");
scanf("%s",name);
strcpy(dd.stu[k].name,name);
save_data();
printf("\n\n修改学生记录(学号-%s)成功!",no);
}
}

// 查询学生成绩(学号)
void query_data_no()
{
int i,k;
char no[10];
printf("\n请输入要查询学生的学号:");
scanf("%s",no);
k=-1;
for(i=0;i<dd.count;i++)
{
if(strcmp(dd.stu[i].no,no)==0)
{
printf("\n\n学号\t姓名\t数学\t英语\t物理");
printf("\n-----------------------------------------------------------------\n");
k=i;
printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
break;//学号应该是唯一的,找到了一个就代表以后的没有了。
}
}
if(k==-1)
{
printf("\n\n没有找到该学生(学号-%s)!",no);
}
}

// 查询学生成绩(姓名)
void query_data_name()
{
int i,k;
char name[10];
printf("\n请输入要查询学生的姓名:");
scanf("%s",name);
k=-1;
for(i=0;i<dd.count;i++)
{
if(strcmp(dd.stu[i].name,name)==0)
{
printf("\n\n学号\t姓名\t数学\t英语\t物理");
printf("\n-----------------------------------------------------------------\n");

k=i;
printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
break;
}
}
if(k==-1)
{
printf("\n\n没有找到该学生(姓名-%s)!",name);
}
}

// 排序(学号)
void sort_data_no(struct data Buff)
{
int i;
int j;
int k;
int h;
struct student temp;
FILE *fp;
if((fp=fopen("D:\\data.txt","w+"))==NULL)
{
printf("cannot open file!\n");
exit(0);
}
printf("请输入要查询的科目:1-数学,2-英语,3-物理:");
scanf("%d",&k);

switch(k)
{
case 1:
for(i=0; i<Buff.count-1; i++)
for(j=i+1; j<Buff.count; j++)
if(Buff.stu[i].math > Buff.stu[j].math)
{
temp=Buff.stu[i];
Buff.stu[i]=Buff.stu[j];
Buff.stu[j]=temp;
}
printf("名次\t学号\t 姓名\t数学\n");
for(i=0; i<Buff.count; i++)
printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].math);
break;
case 2:
for(i=0; i<Buff.count-1; i++)
for(j=i+1; j<Buff.count; j++)
if(Buff.stu[i].eng > Buff.stu[j].eng)
{
temp=Buff.stu[i];
Buff.stu[i]=Buff.stu[j];
Buff.stu[j]=temp;
}
printf("名次\t学号\t 姓名\t英语\n");
for(i=0; i<Buff.count; i++)
printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].eng);
break;
case 3:
for(i=0; i<Buff.count-1; i++)
for(j=i+1; j<Buff.count; j++)
if(Buff.stu[i].phy > Buff.stu[j].phy)
{
temp=Buff.stu[i];
Buff.stu[i]=Buff.stu[j];
Buff.stu[j]=temp;
}
printf("名次\t学号\t 姓名\t物理\n");
for(i=0; i<Buff.count; i++)
printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].phy);
break;
default :
printf("输入错误!");
exit(0);
}

printf("请按任意键继续....");
getch();

fclose(fp);
}

// 主函数
void main()
{
int fun;
dd.count = 0;
read_data();
menu();
while(1)
{
printf("请输入功能号[0-7]:");//这里不需要什么&fun,
scanf("%d",&fun);
switch(fun)
{
case 1: view_data();break; // 查看所有学生信息
case 2: add_data(); break; // 输入学生记录
case 3: delete_data();break; // 删除学生记录
case 4: edit_data();break; // 修改学生记录
case 5: query_data_no();break; // 查询学生成绩(学号)
case 6: query_data_name();break; // 查询成学生绩(姓名)
case 7: sort_data_no(dd); break; // 查看成绩排序(学号) //直接将结构体dd发送过去就可以了
case 0: break; // 退出
}
if(fun==0) break;
to_menu();
}

return;
}
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
我这个配置能玩大唐无双2吗 PK什么的能卡么? 求高手解答 这样的配置还要加什么玩大唐无双才不卡 这个配置能玩大唐无双双开吗? windows7旗舰版系统玩大唐无双零双开卡怎么办?卡死了。 玩大唐无双的时候双开过地图太卡怎么解决啊 全民枪战我用QQ号,但它说密码数字英文,下划线组成,应该怎样弄啊?_百 ... 小太阳取暖器头晕呕吐 取暖器用的会头晕吗,可能的原因和使用注意事项 男孩姓孙含越字好名字 简单特别的男孩名字越 中间是越的男孩名字大全 什么是写法 什么是FAT32文件系统? 发的写法在田字格 在Windows FAT文件系统的文件分配表中记录文件名、属性、大小、创建修改日期等以及分配给文件_百度问一问 写法有哪些 上海服务贸易或(现代服务业的)特点 关于红米note8 pro的wifi问题? 什么是F.A.T.? 劳务收支的服务贸易 关于国际服务贸易出口分项的统计口径介绍? 求:关于国际服务贸易统计口径原理介绍? 什么是统计分布中的“肥尾”【fat tail】? FAT统计和FATS统计是一样的吗 国际服务贸易 bop服务贸易统计与fat服务贸易统计有何区别 一斤鲜香菇烘干后有多重,请指教 植物大战僵尸迷你小游戏第14关 宠物小精灵珍珠/钻石 魔兽RPG仙之侠道--家传衣服怎么和成? 口袋妖怪钻石抓创世神之前要抓其他的PM么?好的加分!!! 写作写法都有哪些 NTFS和FAT32哪个好啊? 我将G:盘的文件管理系统由fat32转化为ntfs后,文件大小统计出现错误 写法是什么意思 写法是什么意思啊 fat control什么意思 作文的所有写法有哪些? 请问“写法”包括什么? 课文写法有哪些 写法特点 各国数字的写法 天水市到酉峰市多少公里 炒股软件上的均线没了,如何显示? 什么手机股票软件可以调整均线的参数 手机软件怎么设置两根obv线,或者那个手机炒股软件有? 在通信达股票软件下(长城证券股票)怎么调节日均线? 茄汁靖鱼 怎么做 茄汁鱼的做法,要正宗哦? 茄汁鲭鱼不用高压锅做法 茄汁鲭鱼什锦烩面应该怎么做?