收藏 分销(赏)

C语言专业课程设计方案报告实验设备标准管理系统.doc

上传人:二*** 文档编号:4516190 上传时间:2024-09-26 格式:DOC 页数:10 大小:42.54KB
下载 相关 举报
C语言专业课程设计方案报告实验设备标准管理系统.doc_第1页
第1页 / 共10页
本文档共10页,全文阅读请下载到手机保存,查看更方便
资源描述
C语言程序设计汇报 一 课程设计目标 提升程序设计能力,检验课堂教学内容,掌握程序设计基础方法和调试技能。 二 课程设计汇报正文 1 课程设计题目标原文; 试验设备信息包含:设备编号、设备种类(如:微机 打印机 扫描仪 等等)、设备名称、设备价格、设备购入日期、是否报废、报废日期等。试设计一试验设备信息管理系统,使之能提供以下功效: (1)能够完成对设备录入和修改 (2)对设备进行分类统计 (3)设备查询 2 需求分析 试验室设备信息用文件存放,提供文件输入输出操作;要能够完成设备录入和修改,需要提供设备添加和修改操作;实现对设备进行分类统计,需要提供排序操作;实现对设备查询需要提供查找操作,设备查询可依据设备编号 设备种类 设备购入日期 正常设备(未报废)等多个方法查询;另外还要依据键盘式选择菜单以实现功效选择。 3总体设计和模块划分 整个系统可设计为试验设备信息输入模块 试验设备信息添加模块 试验设备信息修改模块 试验设备分类统计模块和试验设备查询模块。 4 建立试验设备信息结构体,结构体组员包含设备编号 设备种类 设备名称 设备价格 设备购入日期 是否报废 报废日期。 试验设备信息输入模块 试验设备信息添加模块 试验设备信息修改模块 试验设备分内统计模块 试验设备查询模块 功效选择 试验设备管理系统设计 4 具体设计 A 主函数 void main() { Node *equip; FILE *fp; int flag; Node *p,*q; printf("\t\t\t\t设备管理系统\n"); equip=(Node*)malloc(sizeof(Node)); N 结束 依据n值调用各 功效模块函数 输入n,判定m 是否是0到5? 显示一系列功效选择 开始 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) { case 0: printf("\n>>>>>>>>>>提醒:已经退出系统,ByeBye!\n");break; case 1: Add(equip); break; //增加统计 case 2: Modify(equip); break;//修改统计 case 3: Disp(equip); break;//显示统计信息 case 4: Tongji(equip); break;//统计统计 default: printf("\n>>>>>>>>>>提醒:输入错误!\n"); break; } } } B 各功效模块设计 (1)输入模块 Struct shebei { char ID[10]; char name[15]; char kind[15]; char over[15]; char yesno[10]; char time[10]; char price[10]; }; (2)追加模块 void Add(Node *equip) //添加统计 { Node *p,*r,*s; char id[10]; //先用于输入ID,也用于判定是否跳出循环 r=equip; s=equip->next; //使s为第一个有用结点 while(r->next!=NULL) //这个循环作用是使r为最终一个有用结点 开始 r=r->next; //将指针置于最末尾 while(1) 输入ID号,并将指针置于最末尾 { printf(">>>>>>>>>>提醒:输入0则返回主菜单!\n"); printf("\n请你输入设备ID号:"); scanf("%s",id); if(strcmp(id,"0")==0) break; 依次输入shebei 结构体内容,完成一条添加统计 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 又重设为新链最终一个有用结点 } } (3)修改模块 void Modify(Node *equip)//修改 { Node *p; char find[20]; if(!equip->next) { 开始 N printf("\n>>>>>>>>>>提醒:没有资料能够修改!\n"); return; 判定是否有内容能够修改 } printf("请输入要修改设备ID号:"); scanf("%s",find); p=equip->next; 没有资料能够修改,跳出 while(p!=NULL) { if(strcmp(p->data.ID,find)==0) //假如找到话返回是符合要求 break; 请输入要修改设备ID号 p=p->next; } if(p) //若找到 { int x; 完成修改输入0否着输入任意数进行修改 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"); } } else printf("\n>>>>>>>>>>提醒:你要修改信息不存在!\n"); } (4)输出统计 void Disp(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%-10s%-10s%-10s%-10s%-10s%-10s%-10s\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; } 结 束 有统计者按要求输出 没有统计能够显示,跳出 开始 } (5)统计模块 void Tongji(Node *equip)//统计 { Node *p; int sel;int flag2=0,ha=0; char find[20]; p=equip->next; 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%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price); ha=flag2; } else if(flag2>ha){printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\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);} } else if(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%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price); ha=flag2; } else if(flag2>ha){printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\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);} } else if(sel==0) return; }
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传
相似文档                                   自信AI助手自信AI助手

当前位置:首页 > 学术论文 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服