实验设备管理系统呕心沥血整理版.docx

上传人:b****9 文档编号:24940021 上传时间:2023-06-03 格式:DOCX 页数:29 大小:428.74KB
下载 相关 举报
实验设备管理系统呕心沥血整理版.docx_第1页
第1页 / 共29页
实验设备管理系统呕心沥血整理版.docx_第2页
第2页 / 共29页
实验设备管理系统呕心沥血整理版.docx_第3页
第3页 / 共29页
实验设备管理系统呕心沥血整理版.docx_第4页
第4页 / 共29页
实验设备管理系统呕心沥血整理版.docx_第5页
第5页 / 共29页
点击查看更多>>
下载资源
资源描述

实验设备管理系统呕心沥血整理版.docx

《实验设备管理系统呕心沥血整理版.docx》由会员分享,可在线阅读,更多相关《实验设备管理系统呕心沥血整理版.docx(29页珍藏版)》请在冰豆网上搜索。

实验设备管理系统呕心沥血整理版.docx

实验设备管理系统呕心沥血整理版

 

C语言课程设计

 

一.题目要求

实验设备信息包括:

设备编号,设备种类(如:

微机、打印机、扫描仪等等),设备名称,设备价格,设备购入日期等。

试设计一实验设备信息管理系统,使之能提供以下功能:

(1)能够完成对设备的录入和修改

(2)对设备进行分类统计

(3)设备的查询

二.需求分析

实验室设备信息用文件存储,提供文件的输入输出操作;要能够完成设备的录入和修改,需要提供设备添加和修改操作;实现对设备进行分类统计,需要提供排序操作;实现对设备的插叙需要提供查找操作,设备的查询可根据设备编号、设备种类、设备名称、设备购入日期、正常设备(未报废的)等多种方式查询;另外还要提供键盘式选择菜单以实现功能选择。

三.总体设计

根据上面的需求分析,可以将这个系统的设计分为以下模块

四.详细设计

1.主函数

[流程图]

[程序]

voidmain()

Node*equip;

FILE*fp;

intflag;

Node*p,*q;

printf(”\t\t\t\t设备管理系统\n");

equip=(Node*)malloc(sizeof(Node));

equip-〉next=NULL;

p=equip;

fp=fopen(”设备管理系统”,”wb+”);

q=(Node*)malloc(sizeof(Node));

if(fread(q,sizeof(Node),1,fp))//将文件的内容放入接点中

q—〉next=NULL;

p—〉next=q;

p=q;//将该接点挂入链表中

fclose(fp);//关闭文件

while

(1)

printf(”***************************目录*****************************");

printf("\n1添加记录\n");

printf(”\n2修改记录\n”);

printf("\n3显示记录\n”);

printf(”\n4统计分类记录\n”);

printf("\n0*—EXIT-*\n”);

printf(”请输入你要操作的序号:

”);

scanf("%d",&flag);

switch(flag)

case0:

printf(”\n〉〉>〉〉>〉>>〉提示:

已经退出系统,ByeBye!

\n”);break;

case1:

Add(equip);break;//增加记录

case2:

Modify(equip);break;//修改记录

case3:

Disp(equip);break;//显示记录信息

case4:

Tongji(equip);break;//统计记录

default:

printf(”\n〉〉>〉〉〉>〉〉〉提示:

输入错误!

\n”);break;

2。

各功能模块设计

(1)输入模块

[流程图]

[程序]

/***************************输入模块*****************************/

#include”stdio。

h”

#include”stdlib。

h”

#include"string。

h”

structshebei

charID[10];

charname[15];

charkind[15];

charover[15];

charyesno[10];

chartime[10];

charprice[10];

};

typedefstructnode

structshebeidata;

structnode*next;//建立一个链表。

}Node;

voidAdd(Node*equip)//添加记录

Node*p,*r,*s;

charid[10];//先用于输入ID,也用于判断是否跳出循环

r=equip;

s=equip—〉next;//使s为第一个有用的结点

while(r—>next!

=NULL)//这个循环的作用是使r为最后一个有用的结点

r=r—〉next;//将指针置于最末尾

while

(1)

{

printf(”〉〉〉>〉>〉〉〉〉提示:

输入0则返回主菜单!

\n");

printf(”\n请你输入设备ID号:

”);

scanf(”%s”,id);

if(strcmp(id,”0")==0)break;

p=(Node*)malloc(sizeof(Node));//申请空间

strcpy(p—〉data.ID,id);

printf("\n请输入设备名称:

”);

scanf("%s”,p—>data。

name);

printf("\n请输入设备种类:

");

scanf(”%s”,p—〉data.kind);

printf(”\n请输入报废日期:

");

scanf(”%s”,&p—>data.over);

printf(”\n请输入设备是否报废:

”);

scanf("%s”,&p—>data.yesno);

printf(”\n请输入设备购买时间:

”);

scanf(”%s",&p->data。

time);

printf("\n请输入设备价格:

”);

scanf(”%s",&p—>data。

price);

printf(”〉〉〉>〉〉>〉〉>提示:

已经完成一条记录的添加。

\n");

p—>next=NULL;

r—〉next=p;//这一步是必需的,将p与先前的链表连起来构成一条新链表

r=p;//也是必需的。

将r又重设为新链的最后一个有用结点

}

(2)修改模块

[需求分析]

此模块可以根据客户需要对以记录在文件中的信息进行修改

[流程图]

[程序]

/***************************修改模块*****************************/

voidModify(Node*equip)//修改

Node*p;

charfind[20];

if(!

equip—>next)

printf(”\n〉〉〉>〉>〉>>>提示:

没有资料可以修改!

\n”);

return;

printf(”请输入要修改的设备ID号:

”);

scanf(”%s”,find);

p=equip—〉next;

while(p!

=NULL)

{

if(strcmp(p->data.ID,find)==0)//如果找到的话返回的是符合要求

break;

p=p—〉next;

if(p)//若找到

{

intx;

while

(1)

printf("完成修改请输入0否则输入任意数再进行修改:

");

scanf(”%d",&x);

if(x==0)

{break;}

printf(”请输入新设备号(原来是%s):

”,p—〉data。

ID);

scanf("%s”,p-〉data。

ID);

printf("请输入新设备名称(原来是%s):

”,p—〉data。

name);

scanf(”%s",p—〉data.name);

printf(”请输入新设备设备种类名称(原来是%s):

”,p->data。

kind);

scanf(”%s”,p->data。

kind);

printf("请输入新设备报废日期名称(原来是%s):

”,p->data。

over);

scanf("%s”,p->data.over);

printf(”请输入新设备是否报废(原来是%s):

”,p—>data。

yesno);

scanf("%s",p—>data.yesno);

printf(”请输入新设备购买时间(原来是%s):

”,p->data.time);

scanf(”%s",p—〉data.time);

printf(”请输入新设备价格(原来是%s):

”,p->data。

price);

scanf(”%s”,p-〉data。

price);

printf(”\n>>〉>>>〉〉>〉提示:

该项记录资料已经成功修改!

\n”);

}

elseprintf(”\n〉〉>>〉〉〉〉>〉提示:

你要修改的信息不存在!

\n”);

}

(3)统计模块

[需求分析]

将已经输入的设备信息进行统计,并显示设备总数、价格总额等信息

[流程图]

 

[程序]

voidTongji(Node*equip)//统计

{

Node*p;

intsel;intflag2=0,ha=0;

p=equip—>next;

charfind[20];

if(!

equip—〉next)//若链表为空

printf(”\n>>〉>〉〉>>〉〉提示:

没有资料可以统计分类!

\n”);

return;

}

printf(”〉>〉〉〉〉>>>〉提示:

\n=====〉0退出\n=====>1按设备号统计\n=====>2按设备名称统计\n”);

scanf("%d”,&sel);

if(sel==1)

{

printf(”\n输入你要统计分类的设备号:

");

scanf(”%s”,find);

while(p)

if(strcmp(p—〉data.ID,find)==0)

{

flag2++;

if(flag2==1&&ha!

=flag2)

{printf("设备号设备名称设备种类报废日期是否报废购买时间价格\n");

printf(”\n%-13s%-11s%—7s%—10s%—13s%—10s%-5s\n",p—〉data.ID,p—〉data.name,p—>data.kind,p—>data。

over,p—〉data。

yesno,p-〉data。

time,p—〉data。

price);

ha=flag2;

elseif(flag2>ha){printf("\n%—13s%-11s%—7s%-10s%-13s%—10s%—5s\n",p—〉data。

ID,p—>data。

name,p—〉data。

kind,p—>data.over,p->data。

yesno,p—〉data.time,p-〉data.price);ha=flag2;}

p=p—>next;

if(flag2)

{

printf("\n*************************按设备号%s统计分类的有%d条记录:

*************************\n\n”,find,flag2);

else{printf("\n按设备号%s统计的结果为0个\n\n",find);}

}

elseif(sel==2)

{

printf("\n输入你要统计分类的设备名称:

");

scanf("%s”,find);

while(p)

{

if(strcmp(p—〉data。

name,find)==0)

flag2++;

if(flag2==1&&ha!

=flag2)

{printf(”设备号设备名称设备种类报废日期是否报废购买时间价格\n”);

printf(

”\n%-13s%-11s%-7s%—10s%—13s%—10s%-5s\n”,p->data。

ID,p-〉data.name,p-〉data。

kind,p—〉data。

over,p—>data.yesno,p-〉data。

time,p—〉data。

price);

ha=flag2;

elseif(flag2〉ha){printf(

”\n%—13s%—11s%-7s%-10s%-13s%-10s%-5s\n”,p-〉data.ID,p—>data。

name,p-〉data.kind,p-〉data。

over,p—〉data。

yesno,p-〉data.time,p—>data.price);ha=flag2;}

p=p—〉next;

if(flag2)

{

printf(

"\n******************按设备名称%s统计的有%d条记录:

********************\n\n",find,flag2);

else{printf(”\n按设备名称%s统计分类的结果为0个\n\n”,find);}

}

elseif(sel==0)return;

(4)显示模块

[需求分析]

该模块的功能是查找用户需要的对应记录,可以分别根据设备编号、设备种类、设备名称、设备购入日期、正常设备(未报废的)等多种方式查询.

[流程图]

y

[程序]

/*******************************显示模块******************************/

voidDisp(Node*equip)//输出记录

Node*p;

p=equip->next;

if(!

p)

printf(”\n〉〉〉>〉〉>〉〉〉提示:

没有记录可以显示!

\n”);

return;

printf(”\t\t\t\t显示结果\n”);

printf("设备号设备名称设备种类报废日期是否报废购买时间价格\n");

while(p)

printf(”\n%—13s%-11s%—7s%—10s%—13s%-10s%-5s\n”,p—>data。

ID,p—〉data。

name,p—〉data。

kind,p—〉data。

over,p—〉data。

yesno,p-〉data。

time,p—>data。

price);

p=p—〉next;

五.完整程序

#include”stdio。

h”

#include”stdlib。

h”

#include”string.h”

structshebei

charID[10];

charname[15];

charkind[15];

charover[15];

charyesno[10];

chartime[10];

charprice[10];

};

typedefstructnode

structshebeidata;

structnode*next;//建立一个链表。

}Node;

voidAdd(Node*equip)//添加记录

{

Node*p,*r,*s;

charid[10];//先用于输入ID,也用于判断是否跳出循环

r=equip;

s=equip—>next;//使s为第一个有用的结点

while(r—>next!

=NULL)//这个循环的作用是使r为最后一个有用的结点

r=r-〉next;//将指针置于最末尾

while

(1)

{

printf(”>〉〉>〉〉>〉〉〉提示:

输入0则返回主菜单!

\n”);

printf("\n请你输入设备ID号:

");

scanf("%s”,id);

if(strcmp(id,”0”)==0)break;

p=(Node*)malloc(sizeof(Node));//申请空间

strcpy(p—〉data.ID,id);

printf("\n请输入设备名称:

");

scanf(”%s”,p—>data.name);

printf(”\n请输入设备种类:

");

scanf(”%s”,p-〉data.kind);

printf("\n请输入报废日期:

”);

scanf(”%s”,&p—〉data.over);

printf(”\n请输入设备是否报废:

");

scanf(”%s",&p—>data.yesno);

printf(”\n请输入设备购买时间:

”);

scanf("%s",&p->data。

time);

printf(”\n请输入设备价格:

”);

scanf(”%s",&p—〉data。

price);

printf("〉〉>〉〉>>〉〉>提示:

已经完成一条记录的添加。

\n”);

p—〉next=NULL;

r—〉next=p;//这一步是必需的,将p与先前的链表连起来构成一条新链表

r=p;//也是必需的。

将r又重设为新链的最后一个有用结点

voidModify(Node*equip)//修改

{

Node*p;

charfind[20];

if(!

equip-〉next)

printf(”\n>〉>>>〉〉〉〉>提示:

没有资料可以修改!

\n”);

return;

printf(”请输入要修改的设备ID号:

”);

scanf(”%s”,find);

p=equip-〉next;

while(p!

=NULL)

if(strcmp(p—>data.ID,find)==0)//如果找到的话返回的是符合要求

break;

p=p—>next;

if(p)//若找到

{

intx;

while

(1)

printf(”完成修改请输入0否则输入任意数再进行修改:

”);

scanf(”%d”,&x);

if(x==0)

{break;}

printf(”请输入新设备号(原来是%s):

”,p—〉data。

ID);

scanf(”%s",p—〉data.ID);

printf("请输入新设备名称(原来是%s):

",p-〉data.name);

scanf(”%s",p-〉data。

name);

printf("请输入新设备设备种类名称(原来是%s):

”,p-〉data。

kind);

scanf(”%s”,p—〉data。

kind);

printf(”请输入新设备报废日期名称(原来是%s):

”,p-〉data。

over);

scanf("%s",p->data。

over);

printf(”请输入新设备是否报废(原来是%s):

",p—〉data.yesno);

scanf("%s",p—〉data.yesno);

printf("请输入新设备购买时间(原来是%s):

",p—〉data.kind);

scanf(”%s”,p—〉data。

time);

printf("请输入新设备价格(原来是%s):

”,p->data。

price);

scanf("%s”,p—〉data。

price);

printf(”\n〉>>〉>〉〉〉〉〉提示:

该项记录资料已经成功修改!

\n");

elseprintf(”\n〉〉〉〉〉〉>>>>提示:

你要修改的信息不存在!

\n");

voidDisp(Node*equip)//输出记录

Node*p;

p=equip—>next;

if(!

p)

printf(”\n>〉>>〉>>〉>〉提示:

没有记录可以显示!

\n");

return;

printf(”\t\t\t\t显示结果\n");

printf(”设备号设备名称设备种类报废日期是否报废购买时间价格\n”);

while(p)

printf(”\n%—13s%—11s%—7s%—10s%-13s%—10s%-5s\n”,p—>data。

ID,p-〉data.name,p—>data。

kind,p—〉data。

over,p—〉data。

yesno,p—〉data.time,p-〉data.price);

p=p—>next;

}

}

voidTongji(Node*equip)//统计

Node*p;

intsel;intflag2=0,ha=0;

p=equip—>next;

charfind[20];

if(!

equip-〉next)//若链表为空

printf(”\n〉〉>〉>〉〉〉〉>提示:

没有资料可以统计分类!

\n");

return;

printf("〉〉〉>>>〉>>>提示:

\n=====>0退出\n=====〉1按设备号统计\n=====〉2按设备名称统计\n”);

scanf(”%d”,&sel);

if(sel==1)

printf("\n输入你要统计分类的设备号:

”);

scanf("%s”,find);

while(p)

if(strcmp(p—>data。

ID,find)==0)

flag2++;

}

if(flag2==1&&ha!

=flag2)

{printf(”设备号设备名称设备种类报废日期是否报废购买时间价格\n");

printf("\n%—13s%—11s%—7s%—10s%—13s%-10s%—5s\n",p-〉data.ID,p—〉data.name,p-〉data.kind,p—〉data。

over,p—〉data。

yesno,p-〉data。

time,p—>data.price);

ha=flag2;

}

elseif(flag2〉ha){printf(”\n%—13s%—11s%—7s%-10s%—13s%—10s%-5s\n”,p-〉data。

ID,p—〉data.name,p—>data。

kind,p—〉data.over,p—>data。

yesno,p—〉data。

time,p—>data。

price);ha=flag2;}

p=p-〉next;

}

if(flag2)

printf(”\n*************************按设备号%s统计分类的有%d条记录:

*************************\n\n",find,flag2);

else{printf("\n按设备号%s统计的结果为0个\n\n",find);}

elseif(sel==2)

{

printf(”\n输入你要统计分类的设备名称:

”);

scanf(”%s”,find);

while(p)

if(strcmp(p-〉data.name,find)==0)

flag2++;

if(flag2==1&&ha!

=flag2)

printf(”设备号设备名称设备种类报废日期是否报废购买时间价格\n”);

printf("\n%—13s%—11s%—7s%—10s%-13s%-10s%—5s\n”,p—〉data。

ID,p-〉data。

name,p-〉data.kind,p—>data。

over,p->data。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > PPT模板 > 中国风

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1