数据结构课程设计——仓库管理系统源程序_第1页
数据结构课程设计——仓库管理系统源程序_第2页
数据结构课程设计——仓库管理系统源程序_第3页
数据结构课程设计——仓库管理系统源程序_第4页
数据结构课程设计——仓库管理系统源程序_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、#include using namespace std; typedef structchar no10;char name30; int count;DataType;struct NodeDataType data;Node *next; ;class Link public:Link(); / 构造函数,建立单链表 int Insert(); / 插入节点,即添加货物 Node * Search(); / 查找某个节点 void Delete(); / 删除节点或更改节点的数据 void show(); / 输出节点信息 char Yn(); / 输入( y/n )函数 char *

2、No(); / 输入货物编号函数 void Fprintf(); / 将单链表数据写到文件中 void Fscanf(); / 读取文件中的数据private:Node *first,*real,*p,*q; ;int main()int t=1,flag=1,f=1; char n;Node * p; Link Ku; while(t)printf(nnnnn);printf(nttt*XXX仓库管理系统printf(nttt*1-存储货物*printf(nttt*2-查询货物信息*printf(nttt*3-取出货物*printf(nttt*4-显示仓库内所有货物信息*printf(ntt

3、t*0-退出仓库管理系统*printf(nttt*);*);printf(nttt 请选择菜单号 (0-4):);f=1;printf(ntttwhile(f=1) cinn; if(n4) printf( 输入有误,请重新输入 (0-4): ); f=1;elsef=0;printf(nn);switch(n)case 1:printf(*n);printf(*存储货物*n);printf(n 货物编号 货物名称 货物数量 n);printf(*n);/printf(货物编号货物名称 货物数量 n);/printf( *n);int a=1;while(a=1)a=Ku.Insert();K

4、u.Fprintf();/ 将单链表里的数据写入文件。 break;case 2:printf(*n);printf(* 查询货物信息*n);printf(*n);flag=1; char yn;while(flag=1)p=Ku.Search();if(p)n);printf( printf(%5s%9s%8dn,p-data.no,,p-data.count);n);printf(elseprintf( 仓库中没有该货物! n); printf( 是否继续查询? (y/n):); yn=Ku.Yn();if(yn=y|yn=Y)flag=1;if(yn=n|yn=N)

5、flag=0;break;case 3:printf(*n);printf(* 取出货物*n);printf(*n);flag=1;char yn; while(flag=1) Ku.Delete();printf( 是否继续取货? (y/n):); yn=Ku.Yn();/ 调用输入 y/n 函数 if(yn=y|yn=Y)flag=1;if(yn=n|yn=N)flag=0;break;case 4: case 0:Ku.show();break;char yn;(y/n):);printf( 确定退出仓库管理系统吗? yn=Ku.Yn();/ 调用输入 y/n 函数 if(yn=y|yn

6、=Y)printf( 谢谢使用 .n); t=0;if(yn=n|yn=N)t=1; break;return 0;Link:Link()first=new Node; first-next=NULL;real=first;FILE *fp=NULL; fp=fopen(d:file01.txt,a); fclose(fp);/Fprintf();Fscanf();int Link:Insert()char yn;char no10,name30;int count,t;n);printf(n 货物编号 货物名称 (30) 货物数量 (5) printf(n);printf(n 请输入货物编号

7、 (10 个字符以内 ):n); strcpy(no,No();printf(n 输入货物名称 (30 个字符以内 ):n); cinname;t=1;while(t)printf( 输入货物数量 (整数): ); cincount;if(countnext; while(p)if(strcmp(p-data.no,no)=0&strcmp(,name)=0)printf(” 仓库中已有该货物 %d 件n,p-data.count); p-data.count=p-data.count+count;printf( 添 加 成 功 ! 仓 库 中 现 有 该 货 物 %d

8、件 n 是 否 继 续 存 货 ?(y/n):,p-data.count);yn=Yn();if(yn=y|yn=Y) return 1;if(yn=n|yn=N) return 0;if(strcmp(p-data.no,no)=0&strcmp(,name)!=0)printf(该货物的名称输入有误,应为sn请重新输入(y)或取消存货(n):,);yn=Yn();if(yn=y|yn=Y) return 1;if(yn=n|yn=N) return 0;if(strcmp(p-data.no,no)!=0&strcmp(,n

9、ame)=0)printf(该货物的编号输入有误,应为%sn请重新输入(y)或取消存货(n):,p-data.no);yn=Yn();if(yn=y|yn=Y) return 1;if(yn=n|yn=N) return 0;real=p;p=p-next;if(p=NULL)Node *s=new Node;strcpy(s-data.no,no);strcpy(,name);s-data.count=count;s-next=NULL;real-next=s;real=s;printf( 添 加 成 功 ! 仓 库 中 现 有 该 货 物 %d 件 n 是 否 继 续

10、 存 货 ? (y/n):,real-data.count);yn=Yn();if(yn=y|yn=Y) return 1;if(yn=n|yn=N) return 0;return 0;Node * Link:Search()char ab;char no10,name30;int f;p=first;printf(=n); printf(a. 按货物编号查询n);printf(b. 按货物名称查询n);printf(=n);printf(”请选择(a/b):”);f=1;while(f=1)cinab;if(ab=a|ab=A|ab=b|ab=B)f=0;if(ab=a|ab=A)prin

11、tf(n 请输入货物编号 (10 个字符内 ):n);strcpy(no,No();while(p&strcmp(p-data.no,no)!=0)p=p-next;if(ab=b|ab=B)printf(n 请输入货物名称 (30 个字符内 ): );cinname;while(p&strcmp(,name)!=0)p=p-next;elsef=1;printf( 输入有误,请重新输入 (a/b) :);return p;void Link:Delete()Node *q,*p;int count,t;char yn;p=Search();if(p=NULL)print

12、f( 仓库中没有该货物! n);elseprintf(n 仓库中有该货物 %d 件。 ,p-data.count);int flag=1;while(flag=1)printf(n 请输入要取出的货物数量 (整数 ):); t=1;while(t=1)cincount; if(countp-data.count)printf(n 输入的取货数量超过库存,是否要重新输入取货数量? yn=Yn();if(yn=y|yn=Y) flag=1; if(yn=n|yn=N) flag=0;elseflag=0;if(countdata.count) p-data.count=p-data.count-c

13、ount; Fprintf();/ 修改文件里的数据。 printf(n 取货成功!仓库中还有该货物 %d 件 n,p-data.count); printf(n 是否继续取出该货物? (y/n):);yn=Yn();if(yn=y|yn=Y)flag=1;if(yn=n|yn=N)flag=0;elseq=first;while(q!=NULL&q-next!=p)q=q-next;q-next=p-next;delete p;Fprintf();/ 将单链表里的数据写入文件。printf(n 取货成功!该货物已被全部取出! n);void Link:show()if(first-next=

14、NULL)printf( 仓库内没有货物! );elseprintf( 货物编号 货物名称 货物数量 n);printf(n);p=first-next;while(p) printf(%15s%23s%23dn,p-data.no,,p-data.count); p=p-next;printf(n);char Link:Yn()int f=1;char yn;while(f=1)cinyn;if(yn=y|yn=Y|yn=n|yn=N)f=0;return yn;elsef=1;printf( 输入有误,请重新输入 (y/n) : );char * Link:No()int t=1,i;char *no=NULL,no110;while(t)t=0;cinno1;no=no1;for(i=0;noi;i+)if(noi9)t=1;(10 个字符printf( 货物编号只能由 0-9 的字符组成,请重新输入货物编号 内):);break;return no1;void Link:Fprintf()FILE *fp=NULL; fp=fopen(d:file01.txt,w); p=first-next; while(p!=NULL)fprintf(fp,%10s%30s%10dn,p-data.n

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论