ImageVerifierCode 换一换
格式:DOC , 页数:32 ,大小:362KB ,
资源ID:9867263      下载积分:8 金币
验证码下载
登录下载
邮箱/手机:
图形码:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/9867263.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请。


权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4009-655-100;投诉/维权电话:18658249818。

注意事项

本文(物品管理系统课程设计.doc)为本站上传会员【可****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

物品管理系统课程设计.doc

1、计算机学院 《高级语言程序设计》课程设计报告 学号 2014-2015学年 第二学期 1308210123 《高级语言程序设计》 课程设计报告 题目: 物品管理系统 专业: 计算机科学与技术 班级: 姓名: 指导教师: 成绩: 计算机学院 2015 年 4月 29 日 目录 1设计内容及要求 2 1.1概述 2 1.2主要功能 2 1.3设计目的及具体要求 2 2 概要设计 2 2.1系统的功能简介 2 2.2 总体程序框图 3 2.3各个模块之间的主要关系

2、3 3设计过程及程序代码 3 3.1定义结构体及宏定义 4 3.2主函数 main() 4 3.3输入物品信息函数 5 3.4输出显示物品函数 5 3.5将物品写入磁盘 6 3.6插入物品记录函数 7 3.7 删除一个物品记录函数 7 3.8按照物品编号进行递增排序函数 8 3.9按照物品总价进行递增排序函数 8 3.10对物品记录进行排序函数 9 3.11输出头部信息函数 10 3.12输出一条物品信息函数 10 3.13判断该编号物品是否存在函数 10 3.14根据物品编号进行查找函数 10 3.15根据物品名字进行查找函数 10 3.16对物品记录进行查

3、找函数 11 4设计结果与分析 12 4.1各个模块的程序流程图 12 1)①主函数程序(N-S)流程图及运行界面 12 2)①输入物品记录信息的(N-S)流程图及程序运行界面 13 5设计心得 21 6参考文献 22 7源程序代码(物品管理系统) 23 1 1设计内容及要求 1.1概述 《物品管理系统》主要根据课程设计要求进行设计,从对物品的简单处理着手设计的一份物品管理系统。 1.2主要功能 物品管理系统是一个针对物品管理的系统。该系统功能主要包括八大模块: 1) 输入物品记录:输入物品个数,根据物品个数依次输入每个物品记录的详细信息。例如物品编

4、号、 名字、单价、数量。 2)输出物品记录:对已经写入磁盘的记录信息的显示。若无数据,则显示无数据! 3) 将物品记录写入文件。 4) 插入一个物品记录。 5) 删除一个物品记录。 6)对物品记录进行排序。 7)对物品记录进行查找。 8) 退出系统。 1.3设计目的及具体要求 主要利用c语言的文件操作能力设计开发一个小型的管理信息系统,至少具有如下功能:物品的读和写、物品信息的增删改、物品信息的排序、查找。操作界面要符合用户的一般习惯,图形或文本界面都可以。 要求:系统以菜单方式工作,根据菜单项序号提示进行工作。物品信息包括编号、名称、单价、 数量、总价。系统以菜

5、单方式工作,实现对物品信息的录入、修改、统计、排序、查询、输出等功能。 2 概要设计 2.1系统的功能简介 该系统的主要功能是系统以菜单方式工作,实现对物品信息的录入,修改,统计,排序,查询,输出等功能。 2.2 总体程序框图 物品管理系统操作主要流程如下,各个函数分别实现不一样的功能。 物品管理系统 输入物品记录 输出物品记录 将 物品记录写入文件 输入所选项菜单项序号 插入一个 物品记录 删除一个物品记录 对物品记录进行排序 对物品记录进行查找 退出系统 图3-A总体程序流程图 2.3各个

6、模块之间的主要关系 该程序的功能主要是实现物品信息的录入,并对物品的相应信息进行进本的增删改的计算。各个模块之间的关系是相互联系的。首先,主函数包含了所有的子函数。主函数是整个程序的核心。子函数之间也是有联系的,对物品读取,插入删除,检索排序必须是在主函数的情况下进行的。因此在第一步选择菜单项的 是非常重要的。第一步菜单项的选择决定用户所要实现的操作功能。 3设计过程及程序代码 整个系统除了主函数外,另外还有8个函数,实现7大功能:输入功能、输出功能、写入磁盘功能、插入并显示功能、删除并显示功能、分类查找并显示功能、分类排序并显示功能。各个函数的详细设计说明分别如下: 3.1定义结

7、构体及宏定义 #include "stdio.h" #include "string.h" #define NAME_MAX_LEN 20 #define Prod_MAX_NUM 50 typedef struct { int num; char name[NAME_MAX_LEN]; double unitprice; int amount; double totalprice; }prodNode; typedef struct sequence { prodNode data[Prod_MAX_NUM]

8、 int len; }seq; seq product; 3.2主函数 main() void main() { int menuItemCode=1; product.len=0; while (menuItemCode!=0) { printf("\n\n"); printf("*********物品管理系统************\n"); printf("* 1.输入物品记录 *\n"); printf("*

9、2.输出物品记录 *\n"); printf("* 3.将物品记录写入文件 *\n"); printf("* 4.插入一个物品记录 *\n"); printf("* 5.删除一个物品记录 *\n"); printf("* 6.对物品记录进行排序 *\n"); printf("* 7.对物品记录进行查找 *\n"); printf("* 0.退出系统

10、 *\n"); printf("*********************************\n"); printf("请输入所选项菜单项序号:"); scanf("%d",&menuItemCode); switch (menuItemCode) { case 1:inputGoods(); break; case 2:outputGoods(); break; case 3:saveGoods(); break;

11、 case 4:insertOneGoods(); break; case 5:deleteOneGoods(); break; case 6:sortGoods(); break; case 7:searchGoods(); break; case 0:break; default:printf("输入超出范围!\n"); break; } } } 3.3输入物品信息函数 void inputGoods() { int i,n; printf("请输入物

12、品个数:\n"); scanf("%d",&n); if (n<0) return; for (i=0;i

13、f",&product.data[i].unitprice); printf("输入物品的数量:\n"); scanf("%d",&product.data[i].amount); product.data[i].totalprice=product.data[i].unitprice*product.data[i].amount; } product.len=n; } 3.4输出显示物品函数 void outputGoods() { int i; if (product.len==0) {

14、 printf("\n无数据!\n"); return; } printf("\n物品的记录为:\n"); printf("编号\t名字\t单价 \t数量\t总价\n"); for (i=0;i

15、].totalprice); printf("\n"); } } 3.5将物品写入磁盘 void saveGoods() { int i; FILE *fp; if (product.len==0) { printf("\n无数据!\n"); return; } fp=fopen("D:\\goods.txt","w"); if (fp==NULL) { printf("文件打开失败!\n"); r

16、eturn; } fprintf(fp,"%s\t","编号"); fprintf(fp,"%s\t","名称"); fprintf(fp,"%s\t ","单价"); fprintf(fp,"%s\t","数量"); fprintf(fp,"%s","总价"); for (i=0;i

17、oduct.data[i].name); fprintf(fp,"%lf\t",product.data[i].unitprice); fprintf(fp,"%d\t",product.data[i].amount); fprintf(fp,"%.2lf",product.data[i].totalprice); } fclose(fp); printf("已成功存盘!\n"); } 3.6插入物品记录函数 void insertOneGoods() { prodNode G; int i,pos;

18、 if (product.len==Prod_MAX_NUM) { printf("表已满!\n"); return; } printf("请输入插入位置:"); scanf("%d",&pos); if (pos<0||pos>product.len) { printf("插入位置出错!\n"); return; } printf("请输入要插入的物品记录:\n"); printf("请输入编号:"); do { scanf("%d",&G.num); if (G.num<=0) printf("输入的编

19、号不合理,请重新输入。\n"); }while (G.num<=0); printf("输入物品的名字:\n"); scanf("%s",G.name); printf("输入物品的单价:\n"); scanf("%lf",&G.unitprice); printf("输入物品的数量:\n"); scanf("%d",&G.amount); G.totalprice=G.unitprice*G.amount; for (i=product.len-1;i>=pos;i--) product.data[i+1]=produc

20、t.data[i]; product.data[pos]=G; product.len=product.len+1; printf("插入成功!"); } 3.7 删除一个物品记录函数 void deleteOneGoods() { int i,pos; if (product.len==0) { printf("表空!\n"); return; } printf("请输入要删除的物品记录的位置:"); scanf("%d",&pos); if (pos<0||pos>product.len-1) { printf("删除的

21、位置出错!\n"); return; } for (i=pos+1;i<=product.len-1;i++) product.data[i-1]=product.data[i]; product.len=product.len-1; printf("删除成功!\n"); } 3.8按照物品编号进行递增排序函数 void bubbleSortByNum() { int i,j,n; prodNode temp; int tag; n=product.len; for (tag=1,i=0;i

22、 tag=0; for (j=n-1;j>i;j--) if (product.data[j].num

23、 n=product.len; for (tag=1,i=0;ii;j--) if (product.data[j].totalprice

24、函数 void sortGoods() { int subMenuItem=1; while (subMenuItem!=0) { printf("\n\n"); printf("******************排序子菜单***********************\n"); printf("* 1.按照物品编号进行递增排序 *\n"); printf("* 2.按照物品总价进行递增排序 *\n"); printf("* 0.退

25、出子菜单 *\n"); printf("***************************************************\n"); printf("请输入所选子菜单项序号:"); scanf("%d",&subMenuItem); switch (subMenuItem) { case 1: bubbleSortByNum(); printf("已按照物品的编号进行递增排序。排序后的结果为:\n"); outputGoods(); break; case 2:

26、 bubbleSortByTotal(); printf("已按照物品的总价进行递增排序。排序后的结果为:\n"); outputGoods(); break; case 0:break; default:printf("输入超出范围!\n"); break; } } } 3.11输出头部信息函数 void outputHead() { printf("编号\t名字\t单价 \t数量\t总价\n"); } 3.12输出一条物品信息函数 void outputOneGoods(prodNode s) {

27、 printf("%d\t%s\t%lf \t%d\t%.2lf",s.num,s.name,s.unitprice,s.amount,s.totalprice); printf("\n"); } 3.13判断该编号物品是否存在函数 int isNumberExist (int number) { int n,i=0; n=product.len; while (i

28、据物品编号进行查找函数 void seqSearchByNumber (int number) { int pos; pos=isNumberExist(number); if (pos !=-1) { printf("查找成功!查找结果如下:\n"); outputHead(); outputOneGoods(product.data[pos]); } else printf("查找失败!编号为%d的物品不存在。\n",number); } 3.15根据物品名字进行查找函数 void seqSearchByName(char na

29、me[]) { int flag=0; int n,i; n=product.len; i=0; while (i

30、失败!名字为%s的物品不存在。\n",name); } 3.16对物品记录进行查找函数 void searchGoods() { int number; char name[NAME_MAX_LEN]; int subMenuItem=1; while (subMenuItem!=0) { printf("\n\n"); printf("*********************查找子菜单********************\n"); printf("* 1.根据物品编号进行查找 *\n")

31、 printf("* 2.根据物品名字进行查找 *\n"); printf("* 0.退出系统 *\n"); printf("***************************************************\n"); printf("请输入所选子菜单项序号:"); scanf("%d",&subMenuItem); switch (subMenuItem) { case 1: printf("

32、请输入要查找的物品编号:"); scanf("%d",&number); seqSearchByNumber(number); break; case 2: printf("请输入要查找的物品名字:"); scanf("%s",name); seqSearchByName(name); break; case 0:break; default:printf("输入超出范围!\n"); break; } } } 4设计结果与分析 4.1各个模块的程序流程图 1)①主函数程序(N-S)流

33、程图及运行界面 主函数程序(N-S)流程图 定义变量int menuItemCode=1;product.len=0; while(menuItemCode!=0) scanf("%d",&menuItemCode); switch (menuItemCode) case 1:inputGoods(); break;请输入物品记录 case 2:outputGoods(); break;显示物品记录 case 3:saveGoods(); break;将物品记录存盘 case 4:insertOneGoods()

34、 break;插入一个物品记录 case 5:deleteOneGoods();break;删除一个物品记录 case 6:sortGoods(); break;将物品记录排序 case 7:searchGoods(); break;查找物品记录 case 0: break; 退出系统 返回程序主界面 简单说明:该功能主要显示给用户一个进入界面,它主要的是显示该程序主要能够执行的有哪些功能。根据用户输入的不同的菜单项对应不同的功能。 主菜单 2)①输入物品记录信息的(N-S)流程图及程序运行界面 物品记录信息的(N-

35、S)流程图 选择菜单项第一项,输入1 请输入物品个数 请输入第一个物品记录 请输入物品编号 请输入物品名字 请输入物品单价 请输入物品数量 请输入菜单项3将物品记录写入磁盘 该模块主要是对物品信息进行录入,录入的主要有物品记录的编号、名字、单价、数量等信息然后再存盘。 物品信息录入 物品记录信息存盘 物品记录存盘详细信息 输出物品记录 插入物品记录 插入物品之显示结果 删除物品记录 删除物品记录之显示结果 对物品记录按编号递增排序 对物品记录按总价递增排序

36、 查找子菜单界面 根据物品编号查找 根据物品名字查找 退出系统 5设计心得 当把程序写好并进行调试时,并不是一帆风顺的,总会遇到很多在调试时遇到的错误。 1. 首先在定义函数时,不能输入汉字。否则会程序会显示错误。 2.前后定义变量要统一。 3.如果要调用添加函数,修改函数,修改函数,查找函数,统计函数等要在主函数前面进行申明。否则会显示警告。 4.对背景颜色设置的时候,当你输入的颜色在内存中不存在时,运行程序过后,系统会告诉你相应的颜色符号常数及数值。 5.如果程序在运行的过程中,对于一个循环语句,如果你返回的值始终是真的,那么程序将

37、进如死循环。 6. 未注意int,float型数据的数值范围,int型数据的数值范围(-32768~32768)。对定义物品单价变量时,如果将物品单价定义为float型,将会出现警告。 7.对应该有花括弧的复合语句,忘记加花括弧。 8. 所调用的函数在调用语句之后才定义,而又在调用前未加说明。 物品管理系统对物品的基本操作有助于用户对数据表的监管及应用,在本课程设计的设计过程中,我刚开始感觉到有点头痛。要通过一学期C语言的学习后将所学知识运用起来有点困难,但回过头来再去看教课书,对于这些知识点有关的背景,概念和解决方案更进一步的理解,感觉也不是很难。 另外我还体会了从事C语言

38、课程设计工作需要特别谨慎认真地态度和作风,一点都不能马虎。每个细微的细节都必须十分注意,如果不认真思考,就会出现或大或小的错误。如果把早期的错误隐藏下来,对后面的工作影响就会很大,甚至有时会推倒很多前面做的工作。有时候,我自己觉得我写的程序非常正确,但是就是编译通不过,在查找错误的过程中,面临着否认自己的过程,非常的痛苦,而且由于自己的经验及各方面的能力的不足,所以进展的速度非常的缓慢,往往几天的时间没有一点进展。这时候,我一般是先自己通过书本,手册和资料找解决办法,实在没辙才向老师同学请教。 经过几周的课程设计,我学到了很多东西: ①巩固和加深了对编程的理解,提高综合运用本课程所学知识

39、的能力。 ②培养了我选用参考书,查阅手册及文献资料的能力。培养独立思考,深入研究,分析问题、解决问题的能力。 ③经过实际编译系统的分析设计、编程调试,掌握应用软件的分析方法和工程设计方法。 ④能够按要求编写课程设计报告书,能正确阐述设计和实验结果,正确绘制系统和程序框图。 课程设计是把我们所学的理论知识进行系统的总结并应用于实践的良好机会,有利于加强我们用知识理论来分析实际问题的能力,进而加强了我们对知识认识的实践度,巩固了我们的理论知识,深化了对知识的认识,并为走向社会打下一个良好的基础。 在这次课程设计中我遇到许多问题和麻烦,得到了老师的帮助和指导,才能够使得这次课程设

40、计顺利的进行下去,另外,在程序调试过程中,也得到很多同学的帮助,给我及时指出错误,提出许多宝贵意见。在此对老师和同学们表示感谢! 由于我的知识浅薄,经验不足及阅历颇浅,在该系统的设计方面还有很多不足,比如功能过少,界面不醒目等问题,我会在以后的学习过程中,根据具体要求不断的修改、完善,争取使系统慢慢趋于完美。 6参考文献 [1]谭浩强著.C程序设计(第二版).北京:清华大学出版社,1999 [2]谭浩强,张基温,唐永炎编著.C语言程序设计.北京:高等教育出版社,1992 [3]谭浩强.C程序设计[M].3版.北京:清华大学出版社,2005 [4]Herbert S

41、childt著.戴健鹏译.C语言大全(第二版).北京:电子工业出版社,1994 7源程序代码(物品管理系统) #include "stdio.h" #include "string.h" #define NAME_MAX_LEN 20 #define Prod_MAX_NUM 50 typedef struct { int num; char name[NAME_MAX_LEN]; double unitprice; int amount; double totalprice; }prodNode; typedef

42、struct sequence { prodNode data[Prod_MAX_NUM]; int len; }seq; seq product; /*输入物品记录*/ void inputGoods() { int i,n; printf("请输入物品个数:\n"); scanf("%d",&n); if (n<0) return; for (i=0;i

43、编号:\n"); scanf("%d",&product.data[i].num); printf("输入物品的名字:\n"); scanf("%s",product.data[i].name); printf("输入物品的单价:\n"); scanf("%lf",&product.data[i].unitprice); printf("输入物品的数量:\n"); scanf("%d",&product.data[i].amount); product.data[i].totalprice=pr

44、oduct.data[i].unitprice*product.data[i].amount; } product.len=n; } /*输出物品记录*/ void outputGoods() { int i; if (product.len==0) { printf("\n无数据!\n"); return; } printf("\n物品的记录为:\n"); printf("编号\t名字\t单价 \t数量\t总价\n"); for (i=0;i

45、en;i++) { printf("%d\t%s\t%lf\t%d\t%.2lf",product.data[i].num,product.data[i].name,product.data[i].unitprice,product.data[i].amount,product.data[i].totalprice); printf("\n"); } } /*将物品记录写入文件*/ void saveGoods() { int i; FILE *fp; if (product

46、len==0) { printf("\n无数据!\n"); return; } fp=fopen("D:\\goods.txt","w"); if (fp==NULL) { printf("文件打开失败!\n"); return; } fprintf(fp,"%s\t","编号"); fprintf(fp,"%s\t","名称"); fprintf(fp,"%s\t ","单价"); fprintf(fp,"%s\t","数量"

47、); fprintf(fp,"%s","总价"); for (i=0;i

48、 fprintf(fp,"%.2lf",product.data[i].totalprice); } fclose(fp); printf("已成功存盘!\n"); } /*插入一个物品记录*/ void insertOneGoods() { prodNode G; int i,pos; if (product.len==Prod_MAX_NUM) { printf("表已满!\n"); return; } printf("请输入插入位置:"); scanf("%d",&pos); if (pos<0||po

49、s>product.len) { printf("插入位置出错!\n"); return; } printf("请输入要插入的物品记录:\n"); printf("请输入编号:"); do { scanf("%d",&G.num); if (G.num<=0) printf("输入的编号不合理,请重新输入。\n"); }while (G.num<=0); printf("输入物品的名字:\n"); scanf("%s",G.name); printf("输入物品的单价:\n"); scanf("%lf",&G

50、unitprice); printf("输入物品的数量:\n"); scanf("%d",&G.amount); G.totalprice=G.unitprice*G.amount; for (i=product.len-1;i>=pos;i--) product.data[i+1]=product.data[i]; product.data[pos]=G; product.len=product.len+1; printf("插入成功!"); } /*删除一个物品记录*/ void deleteOneGoods() { in

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

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

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

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

gongan.png浙公网安备33021202000488号   

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

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

客服