数据结构课程设计 客户消费积分系统.doc_第1页
数据结构课程设计 客户消费积分系统.doc_第2页
数据结构课程设计 客户消费积分系统.doc_第3页
数据结构课程设计 客户消费积分系统.doc_第4页
数据结构课程设计 客户消费积分系统.doc_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

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

文档简介

课程设计报告 设计题目: 客户消费积分系统 学院、系: 电子与信息工程学 院 专业班级: 学生姓名: 指导教师: 成 绩: 2013年 1 月 8 日目录1、 需求分析21.1问题描述31.2基本要求32、概要设计32.1数据结构.42.2程序模块.4 2.3各模块之间的调用关系以及算法设计.43、详细设计.54、测试与分析.65、总结.106、附录.111、需求分析:11问题描述1、采用动态分配顺序表存储客户信息,并用文件保存和读写数据2、能对客户信息进行添加、查询、修改、删除等基本操作3、根据客户消费额,合理计算出客户消费所得积分4、根据客户积分值,实行不同情况的优惠(即计算折扣)12基本要求进行添加客户时要注意不能超过所定义数组的最大容量,查找时输入的身份证号要求为18位,本程序能对客户信息进行添加、查询、修改、删除等基本操作,根据客户消费额,合理计算出客户消费所得积分,根据客户积分值,实行不同情况的优惠。2、 概要设计 :1. 数据结构 线性表的抽象数据类型定义InitList前置条件:线性表不存在输入:无功能:线性表的初始化输出:无后置条件:一个空的线性表DestroyList前置条件:线性表已存在输入:无功能:销毁线性表输出:无后置条件:释放线性表所占的内存空间Length前置条件:线性表已存在输入:无功能:求线性表的长度输出:线性表中元素个数后置条件:、线性表不变Get前置条件:线性表已存在输入:元素的序号i 功能:在线性表中去序号为i的元素输出:如果序号合法,返回序号为i的元素值,否则抛出异常后置条件:、线性表不变Insert前置条件:线性表已存在输入:插入位置i ,插入元素x功能:在线性表的第i个位置,插入元素X输出:若插入不成功,抛出异常后置条件:若插入成功,表中增加了一个元素Delete前置条件:线性表已存在输入:删除位置i功能:删除线性表的第i个元素输出:若删除成功,返回被删除元素,否则抛出异常后置条件:若删除成功,表中减少了一个元素Print前置条件:线性表已存在输入:无功能:按位置的先后次序依次输出线性表中的元素输出:线性表中的各个元素 后置条件:线性表不变 2. 程序模块主函数main() 动态获取表空间,初始化链表,打开文件将客户数据加载入表中,进行表操作,操作结束将表数据保存到文件,文件关闭。2.1添加客户信息 遍历当前单链表,若待添加的用户编号已存在,则返回用户已存在的提示信息;若待添加的用户不存在,则将该客户信息添加到顺序表最后,并将单链表表长度加1。2.2删除客户信息 遍历当前顺序表,若要删除的用户标号不存在,则返回提示信息;否则提示用户是否确定删除,确定即删除。删除操作即将待删除记录的后面记录依次向前移动1步。2.3更改客户信息遍历当前单链表,若待更改的用户编号不存在,则返回用户不存在的提示信息;若待添加的用户存在,则提示输入新的信息。2.4 查找客户信息输入待查找用户的身份证号,若存在则返回用户的信息2.5 显示客户信息遍历整个单链表,显示当前所有客户2.6 统计客户遍历单链表,统计当前链表中所有客户的总数3. 各模块之间的调用关系以及算法设计 添加客户信息客户消费积分管理系统查找客户信息删除客户信息更改客户信息显示客户信息统计客户总数客户消费积分管理系统功能3、详细设计 添加客户信息伪代码:1.初始化工作指针P,申请空的结点空间;2.输入姓名,输入身份证号;3.若省份证号不等于18,输出输入有误,否则输入消费金额,并调用函数进行折扣计算 ;查找客户信息:1. 初始化工作指针P,工作指针P指向头结点,并定义折扣;2.判断P是否为空,若为空,输出无用户,否则P后移直到身份证号相同;3若相同调用函数计算折扣;更改客户信息:1. 初始化工作指针p ,定义折扣和续加金额;2. 判断指针P是否为空,若为空输出没有客户,否则p后移;3. 判断身份证号是否相同,若相同输出姓名、身份证号、消费、折扣、积分;4. 输入要修改的项目;4.1选择1,输入修改后的姓名 4.2 选择2,输入修改后的身份证号4.3选择3,覆盖以前消费、续加上现在费用;5. 调用积分函数,计算折扣;删除客户信息:1. 初始化工作指针p ,定义折扣;2判断指针P是否为空,若为空输出没有客户,否则p后移;3判断身份证号是否相同,若相同输出姓名、身份证号、消费、折扣、积分;4选择是否删除,选1返回删除成功,选2,返回删除失败;显示客户信息:1初始化工作指针p ,定义折扣;2判断指针P是否为空,若为空输出没有客户,否则p后移;3输出每位姓名、身份证号、消费、折扣、积分统计客户信息:1初始化工作指针p ,累加器i初始化;2判断指针P是否为空,若为空输出没有客户,否则p后移;3累加器i加1;4输出现有客户数量i位;计算折扣函数:1. 定义折扣discount2. 若积分为0,则折扣为0;若积分大于0小于50,则折扣为9;若积分大于等于50,于100,则折扣为8,;若积分大于等于100,小于等于150,则折扣为7;若积分大于等于150,小于等于200,则折扣为7;若积分大于等于150,小于等于200,则折扣为6.5若积分大于等于200,小于等于300,则折扣为6,;若积分大于300,折扣为6.4、测试与分析 添加客户信息:查找客户信息:修改客户信息:删除客户信息:显示客户:统计客户:退出:5、总结: 在本次课程设计当中,我对许多以往掌握不够熟练或者是使用较少而易忽略的知识点有了一定的掌握,而且通过本次试验提高了我的实际操作能力,在编写代码的过程当中,我通过查阅有关的资料和分析实例,从中学到了很多能够不断优化自己代码,可以提高代码利用率的知识,并且更加合理的构建了各个知识点之间的联系,充分的利用了循环和选择性语句,在存储过程中,对文件的部分知识也有了一个深层次的了解和掌握,对于如何修改文件信息以及保存有了一定的概念和运用。 当然,在代码的编写过程中,也遇到了许多问题,我通过自身的努力去改正它们,在这个过程中我也学到了很多东西,在代码的调试过程中,我碰到了许多以前所没有碰到过的错误,但通过同学的帮助解决了这些困难,并且自身得到了一定的提高。通过本学期的学习我对数据结构有了更深的了解,数据结构重在思想,通过学习数据结构的思想和C+结合来编写程序,虽然现在编程仍有许多困难,但以后的学习中,我会更加努力,希望能够不断的提高自己!6、 附录:源程序#includeusing namespace std;struct cnodechar name20;char ID20;double consume;double integer;struct cnode *next;void Initstack(cnode * &head) head= new cnode; head-next=NULL;void Getelem (cnode *head);void Search(cnode *head,char ID);void Amend(cnode *head,char ID);void Delete(cnode *head,char ID);void Showall(cnode *head);void count(cnode *head);double display_discount(double integer);void main() cnode *head; int choice;char y20;Initstack(head); docoutn;cout 客户消费 积分管理系统 nn;cout *;coutn * *n;coutn * 主菜单 *n;coutn * 1 添加客户 *n;coutn * 2 查找客户 *n;coutn * 3 修改客户 *n;coutn * 4 删除客户 *n;coutn * 5 显示客户 *n;coutn * 6 统计客户 *n;coutn * 7 退出 *n;coutn * *n;cout *;coutchoice;if(choice=1)Getelem(head); else if(choice=2) couty;while(strlen(y)!=18)couty; Search(head,y); else if(choice=3)couty;while(strlen(y)!=18)couty;Amend(head,y); else if(choice=4)coutn;couty;Delete(head,y); else if(choice=5)coutn;Showall(head); else if(choice=6)coutn;count(head); else if(choice=7)exit(1);while(choice=7);void Getelem (cnode *head) cnode *p;double y;p=new cnode; /*申请空的节点空间*/coutp-name;coutp-ID;while(strlen(p-ID)!=18)coutp-ID;coutp-consume;p-integer=p-consume/100;y=display_discount(p-integer); cout折扣:;couty;coutnext=head-next;head-next=p;void Search(cnode *head,char ID)cnode *p;double y;p=head;if(p-next=NULL)coutnext!=NULL)p=p-next;if(strcmp(ID,p-ID)=0) cout姓名:;coutname;cout身份证号:;coutID;cout消费:;coutconsume;cout积分:;coutinteger;y=display_discount(p-integer);cout折扣:;couty;coutnext=NULL)coutnext!=NULL)p=p-next;if(strcmp(ID,p-ID)=0) cout姓名:;coutname;cout身份证号:;coutID;cout消费 ;coutconsume;cout积分:;coutinteger;y=display_discount(p-integer);cout折扣:;couty;cout折n;coutchoose;if(choose=1)coutp-name;if(choose=2)coutp-ID;while(strlen(p-ID)!=18)coutp-ID;if(choose=3)coutx;if(x=1)coutp-consume;elsecoutz;p-consume+=z;cout姓名:;coutname;cout身份证号:;coutID;cout消费:;coutconsume; p-integer=p-consume/100;cout积分:;coutinteger;y=display_discount(p-integer);cout折扣:;couty;coutnext=NULL)coutnext!=NULL)head=p;p=p-next;if(strcmp(ID,p-ID)=0) cout姓名:;coutname;cout身份证号:;coutID;cout消费:;coutconsume;cout积分:;coutinteger;y=display_discount(p-integer);cout折扣:;couty;cout折n;coutx;if(x=1)head-next=p-next;cout删除成功!;elsecoutnext=NULL)coutnext!=NULL)p=p-next;cou

温馨提示

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

评论

0/150

提交评论