




已阅读5页,还剩34页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
程序设计综合课程设计 计算机学院计算机科学与技术专业程序设计综合课程设计报告 (2010/2011学年 第一学期)学生姓名: 学生班级: 学生学号: 指导教师: 2011年1月7日36小区楼盘销售管理程序目录一、课程设计目的和要求1二、课程设计任务内容21、课程设计内容:22、设计内容分析2三、详细设计说明31、函数功能说明、参数说明及函数流程图3(1)、int main()4(2)、void input(residence *);6(3)、void del(residence *);7(4)、void amend(residence *);10(5)、void display(residence *);12(6)、void seek(residence *);132、编码153、测试15四、软件使用说明21五、课程设计心得与体会22附录1:参考文献23附录2:程序清单24一、课程设计目的和要求(1)巩固和加深学生对C+课程的基本知识的理解和掌握,通过这次课程设计,使学生从整体上把握一个学期以来所学的C+程序设计的内容,各种程序设计思路进行贯通,从而熟练掌握。(2)掌握C+编程和程序调试的基本技能。C+编程和程序调试是软件设计的重中之重,这两个部分占据了整个程序设计的80%以上的时间。掌握C+编程和调试,是极其重要的。(3)利用C+进行简单软件设计的基本思路和方法。今天我们的程序设计只是一个很小很小的方面而已,从这次课程设计中,我们应该对软件设计有所认识,并且在今后的学习中要为此做出充分的准备。(4)提高运用C+解决实际问题的能力。任何知识的学习的最终目的都是解决实际问题。C+编程在解决实际问题上具有很大的作用。二、课程设计任务内容1、课程设计内容:小区楼盘销售管理程序 要用结构体数组/链表实现,用结构体表示每项记录,包含楼盘数据为:楼编号、单元号、房间号、朝向(如:南北、东西、东南等)、户型、平米单价、建筑面积、总价,售出状态,业务员等,其中总价=单价X 建筑面积。设计各个函数,分别实现以下功能: (1)录入:实现每套房源信息的输入,最好是追加方式; (2)删除:完成房源信息的删除; (3)修改:允许对已经录入的数据重新进行编辑、修改; (4)显示:显示所有房源信息; (5)查询: a) 输入朝向、户型等数据,显示符合该条件的所有记录,最好做到条件动态添加; b)建筑面积范围,显示符合该条件的所有记录; c) 显示所有未售出房源情况; d)查询已售出房源的业务员姓名,成交额及总额 (6) 退出程序。 设计菜单,通过选择菜单调用以上各函数。要求:1)用C语言实现系统;2)函数功能要划分好(结构化程序设计);3)界面友好(良好的人机交互),加必要的注释;4)提供程序测试方案。2、设计内容分析输入项:楼编号、单元号、房间号、朝向(如:南北、东西、东南等)、户型、平米单价、建筑面积、总价,售出状态,业务员等,其中总价=单价X 建筑面积。程序中也会有一些其他的循环条件输入。输出项:小区楼盘房源的相关信息,也就是输入项的用户所需数据。程序功能的实现:程序设计到数据的动态添加、删除、修改、和查询,应使用链表进行存储较为方便。而且应使用一个结构体来对应相应的房间,存储其相关信息。在使用链表上,很多地功能的实现都变得很简单了,条件查找上因该会比较麻烦,应多加考虑。三、详细设计说明1、函数功能说明、参数说明及函数流程图整个程序共包含6个函数:void input(residence *);/ 输入函数void del(residence *);/ 删除函数void amend(residence *);/ 修改函数void display(residence *);/ 显示所有信息void seek(residence *);/ 条件查找函数int main(); /主函数程序中使用了一个结构体,用于存储套房间的相应信息:struct residenceint lou,danyuan,fangjian; /楼号/单元号/房间号string chaoxiang,huxing; /朝向/户型float danjia,mianji,zongjia; /平米单价/面积/总价string zhuangtai,renyuan; /售出状态(yes/no)/销售人员(没有的话为no,有的话输入相应的名字)residence *next; /指针用来指向链表的下一个结点;(1)、int main()函数功能说明:主函数,主要是实现两个功能:一是程序开始运行时的文件数据载入,二是显示主菜单文件载入时先判断文件是否存在,如果不存在,使用outf.open(data.txt,ios:out);进行新建;如果存在,从中读取数据并存入链表中。主菜单放在一个while循环中,通过swicth进行选择相应选项。函数参数说明:int i; 用于菜单选择,不同的值对应不同的菜单Int a; 用于记录载入的数据个数Residence *head,*p1,*p2; 用于链表的创建,head是链表的头结点,p1,p2都是创建链表是的中间变量,起辅助传递作用。函数流程图:ifstream inf(data.txt,ios:in);ofstream outf;if(inf=0)outf.open(data.txt,ios:out);a+;cout数据文件不存在,将新建p1-loup1-danyuan.break;if(inf=0)p2-next=p1;p2=p1;cout共载入a-1个数据endlzongjia=p1-danjia*p1-mianji;来计算,减少用户的工作量。保存数据上,用户每输入完一个房源信息就存储一个,使用的是这个语句:outflou danyuan fangjian danjia mianji zongjia;outf chaoxiang huxing zhuangtai renyuannext=NULLbreak;p1=p1-next;YNp2=head;n!=0p1=new residence;p2-next=p1;cinp1-loup1-danyuan.outflou danyuancinn;outf.close;图2-2图2-2(3)、void del(residence *);函数功能说明:删除数据,并将删除后的数据保存在文件中将楼号、单元号。房间号等信息存储在l、d、f三个变量中,在对查看每个节点时,if(p1-lou=l&p1-danyuan=d&p1-fangjian=f)进行判断。并且,通过判断i是否为零确定删除的数据的个数,如果i为零,提示没有改套房间。数据保存与输入部分是一样的。函数参数说明:residence *head1:存储原链表的头指针int l,d,f,n,i; l、d、f分别用于存储需要查询的房间的楼号、单元号、房间号;n用来判断是否结束修改操作返回主菜单;i用来判断是否删除成功。residence *p1,*p2;中间的指针变量函数流程图:p2=head;p1=head-next;1p1-lou=l&p1-danyuan=d&p1-fangjian=fp2-next=p1-next;delete p1;break;Yp2=p1;p1-next=NULLbreak;Yp1=p1-next;cinn;n!=0p1=head;1p1=p1-next;outflou next=NULL NNbreak;YN图2-3(4)、void amend(residence *);函数功能说明:修改数据,并将修改保存在文件中查找房间所在链表的位置与删除函数是一样的。提示用户是按相应键以做相应修改,并且可以循环修改:cout相应按键为:楼号 1, 单元号 2, 房间号 3, 平米单价 4, 建筑面积 5, 朝向 6, 户型 7, 售出状态 8, 业务员 9,退出 0endl;当用户按0想要结束修改时,程序退出修改模块,进入存储模块,存储完毕提示cout修改已保存ldf;while(1)p2=head;p1=head-next;p1-lou=l&p1-danyuan=d&p1-fangjian=fcini;switch (i)while(i!=0);YNbreak;p1-next=NULLcinn;n=0p1=p1-next;break;YYNN图2-4(5)、void display(residence *);函数功能说明:查看所有房源信息,以列表的方式显示函数参数说明:residence *head1:存储原链表的头指针residence *p1;中间指针变量函数流程图:p1=head-next;while(1)coutsetw(6)setiosflags(ios:left)lou;.p1-next=NULLbreak;p1=p1-next;YN图2-5(6)、void seek(residence *);函数功能说明:条件查询实现的原理:将原链表进行复制,查询的时候对复制链表进行查找,并把不符合条件的节点删除,这样一来剩下的就都是符合条件的节点;如果再次添加条件进行查找,仍旧执行这个操作,从而达到条件查询的目的。其中,使用while(1)进行循环,if语句判断选择的是何种操作。函数参数说明:residence *head2; 存储原链表的头指针int t;用于选择查找条件string s;;存储提供的查询信息:朝向,户型,float m1,m2,q=0; m1,m2分别存储面积范围的左右边界,用于计算已售房源的总金额residence *p1,*p2,*p3,*p4,*head; 除head存储新复制链表的头结点外,其他都是中间指针变量。函数流程图:head=new residence;p3=head;1p2-next=NULLp1=new residence;p3-next=p1;p3-next=p1;YNp2=p2-next;break;图2-6cins;1p2=head;p1=head-next;cint;t=1YN1p1-chaoxiang=scoutsetw(6)setiosflags(ios:left)next;p2-next=p1-next;delete p3;t=2cout返回主菜单;NY.图2-72、编码ASCII。数据也是存储在ASCII文件中,文件名为:data.txt;可以随时查看数据。3、测试初始界面:图3-1输入数据:图3-2输入完成后重新打开程序:图3-3显示所有数据:图3-4删除数据:图3-5图3-6修改数据:图3-7图3-8查询数据:图3-9追加条件:图3-10程序的存在一个bug,按户型查询后,程序不能进入菜单,而是卡死。由于5个if语句中的循环代码是完全一样的,为什么在按户型查询时就出问题,有待解决。初步确定是链表尾结点赋值NULL出错,应属于编译系统的问题。按户型 4-2查找,没问题:图3-11按户型4-1查找,出现错误:图3-12四、软件使用说明1、开始运行程序,显示主菜单。左上角会有提示,显示数据载入的相应情况。按相应数字键即可进入对应功能。2、输入数据输入分为两次,第一次包括:楼号、单元号、房间号、平米单价、建筑面积这5个信息;第二次是朝向、户型、售出状态(yes/no)、业务员(no/业务员姓名)共4个信息;第二次包括:朝向、户型、售出状态(yes/no)、业务员(no/业务员姓名)共4个信息;总价这信息程序会自行计算,用户无需输入。输入完成一次后会提示是否继续:“如果需要结束输入请按0,要继续请按1”用户输入的房源信息会与以前输入的信息放在同一个文件下,不会覆盖。数据时按时间顺序排列的。3、删除数据首先提示输入楼号、单元号、房间号,输入完成后即开始查找删除。如果没有该房源,则会有相应提示。4、修改数据进入修改后,提示按相应键可进行相应修改。用户输入需要修改的房间位置信息,之后按相应的数字即可开始修改。可以修改所以数据。5、显示所有数据显示所有数据,按任意键返回主菜单。6、条件查询提供五总查询方式:朝向(1),户型(2),建筑面积范围(3),显示所有未售出房源(4),查询已售出房源的业务员姓名、成交金额及总额(5);按相应数字进入查找。查找完成后如果想继续添加条件进行查找可继续按相应数字继续,也可按0退出返回菜单。7、退出按0即可。五、课程设计心得与体会这次课程设计让我受益匪浅。学编程这么久,还是头一次写这么大的程序。通过这个,也算体验到了程序设计的艰苦和团队合作的重要性,这也为以后做项目打了一些基础,而且积累了不少程序设计的经验呢。最后,得学习图形用户操作界面的设计了,dos界面确实不怎么好看,而且容易出现一些不必要的问题,比如多输入了一个数据该。总而言之,Still have long way to go.附录1:参考文献1、C+程序设计 钱能 清华大学出版社2、c+程序设计作者:谭浩强 出版时间2004年6月附录2:程序清单#include #include #include #include using namespace std;struct residence/房源信息结构体int lou,danyuan,fangjian;string chaoxiang,huxing;float danjia,mianji,zongjia;string zhuangtai,renyuan;residence *next;int main()void input(residence *);/ok 输入函数void del(residence *);/ok 删除函数void amend(residence *);/ok 修改函数void display(residence *);/ok 显示所有信息void seek(residence *);/ok 条件查找函数/ 函数定义完毕int i;residence *head,*p1,*p2;head=new residence; head-next=NULL;/打开文件进行,从文件进行输入,进入等待状态ifstream inf(data.txt,ios:in);ofstream outf;if(inf=0)/文件不存在,新建cout数据文件不存在,将新建endl;inf.close; outf.open(data.txt,ios:out); outf.close;coutsuccessfull!next=NULL;infp1-loup1-danyuanp1-fangjian;infp1-danjiap1-mianjip1-zongjia;infp1-chaoxiangp1-huxingp1-zhuangtaip1-renyuan;if(inf=0) break; delete p1;p2-next=p1;p2=p1;cout数据载入成功!endl;/文件载入完成cout共载入a-1个数据endlendl;while(1)/菜单cout *欢迎使用小区楼盘销售管理程序* endl;/菜单cout + + endl;cout + + endl;cout + + endl;cout要输入数据请按-1 + endl; cout要删除数据请按-2 + endl;cout要修改数据请按-3 + endl; cout要显示数据请按-4 + endl;cout要查询数据请按-5 + endl; cout要退出请按-6 + endl;cout + + endl;cout + + endl;cout + + endl;cout *欢迎使用小区楼盘销售管理程序*endl;couti;switch(i)case 1: input(head); break;case 2: del(head); break;case 3: amend(head); break;case 4: display(head); break;case 5: seek(head); break;case 6: exit(1); break;return 0;void input(residence *head1)/ofstream outf(data.txt,ios:app);/打开文件,等待数据存储residence *p1,*p2,*head;p1=head1;while (1)if(p1-next=NULL) break;p1=p1-next;head=p1;int n;p2=head;cout开始输入next=NULL;p2-next=p1;cout楼号、单元号、房间号、平米单价、建筑面积这5个信息p1-loup1-danyuanp1-fangjian;cinp1-danjiap1-mianji;p1-zongjia=p1-danjia*p1-mianji;cout请分别输入朝向、户型、售出状态(yes/no)、业务员(no/业务员姓名)共4个信息p1-chaoxiangp1-huxingp1-zhuangtaip1-renyuan;outflou danyuan fangjian danjia mianji zongjia;outf chaoxiang huxing zhuangtai renyuanendl;/输入数据的同时,将数据写入文件cout如果需要结束输入请按0,要继续请按1n;p2=p1;while(n!=0);outf.close;cout数据已保存!endl;void del(residence * head)/int l,d,f,n,i;residence *p1,*p2;cout请输入您要删除的房间的位置信息:楼号,单元号,房间号ldf;doif(head-next=NULL) cout没有数据next;while(1)/查找并删除数据i=0;if(p1-lou=l&p1-danyuan=d&p1-fangjian=f)p2-next=p1-next;delete p1; i+;/删除操作break;if(p1-next=NULL) break;p2=p1;p1=p1-next;if(i!=0) cout删除成功endl;else cout没有该数据endl;cout如果需要结束输入请按0,要继续请按1n;while(n!=0);ofstream outf(data.txt,ios:out);/重新存储数据p1=head;if(p1-next=NULL) cout数据已全部删除!next;outflou danyuan fangjian danjia mianji zongjia;outf chaoxiang huxing zhuangtai renyuannext=NULL) break;outf.close;cout修改已保存endl;void amend(residence *head)/cout已进入修改,完成一次修改后可按0退出next=NULL) cout没有数据endl;return;cout相应按键为:楼号 1, 单元号 2, 房间号 3, 平米单价 4, 建筑面积 5, 朝向 6, 户型 7, 售出状态 8, 业务员 9,退出 0endl;cout请输入您要修改的房间的位置信息:楼号,单元号,房间号ldf;while(1)p2=head;p1=head-next;while (1)if(p1-lou=l&p1-danyuan=d&p1-fangjian=f)/判断条件docout请输入相应的数字i;switch (i)case 1: coutp1-lou;break;case 2: coutp1-danyuan;break;case 3: coutp1-fangjian;break;case 4: coutp1-danjia;p1-zongjia=p1-danjia*p1-mianji;break;case 5: coutp1-mianji;p1-zongjia=p1-danjia*p1-mianji;break;case 6: coutp1-chaoxiang;break;case 7: coutp1-huxing;break;case 8: coutp1-zhuangtai;break;case 9: coutp1-renyuan;break;case 0: break;while(i!=0);/如果不符合条件,继续查找下一个if(p1-next=NULL) break;p2=p1;p1=p1-next;cout要结束修改吗?是:0,否:1n;if(n=0) break;ofstream outf(data.txt,ios:out);/数据存储p1=head;if(p1-next=NULL) cout数据已全部删除!next;outflou danyuan fangjian danjia mianji zongjia;outf chaoxiang huxing zhuangtai renyuannext=NULL) break;outf.close;cout修改已保存endl;coutnext=NULL) cout没有数据endl;return;cout所有房源信息:endlendl;cout楼号 单元号 房间号 平米单价 建筑面积 总价 朝向 户型 售出状态 业务员next;while(1)coutsetw(6)setiosflags(ios:left)lou;/楼号coutsetw(7)setiosflags(ios:left)danyuan;/单元号coutsetw(7)setiosflags(ios:left)fangjian;/房间号coutsetw(9)setiosflags(ios:left)danjia;/平米单价coutsetw(9)setiosflags(ios:left)mianji;/建筑面积coutsetw(10)setiosflags(ios:left)zongjia;/总价coutsetw(7)setiosflags(ios:left)chaoxiang;/朝向coutsetw(12)setiosflags(ios:left)huxing;/户型coutsetw(9)setiosflags(ios:left)zhuangtai;/售出状态coutsetw(6)setiosflags(ios:left)renyuannext=NULL) break;p1=p1-next;coutendl;cout按任意键返回主菜单。next=NULL;p3=head;p2=head2;while (1)/开始复制链表if(p2-next=NULL) break;p1=new residence;p1-next=NULL;p3-next=p1;p2=p2-next;p1-lou=p2-lou;p1-danyuan=p2-danyuan;p1-fangjian=p2-fangjian;p1-danjia=p2-danjia;p1-mianji=p2-mianji;p1-zongjia=p2-zongjia;p1-chaoxiang=p2-chaoxiang;p1-huxing=p2-huxing;p1-zhuangtai=p2-zhuangtai;p1-renyuan=p2-renyuan; if(p2-next=NULL) break;p3=p1;/复制链表完毕p2=head;p1=head-next;cout开始查找next;cout查询方式:朝向(1),户型(2),建筑面积范围(3),显示所有未售出房源(4),查询已售出房源的业务员姓名、成交金额及总额(5),退出 0t;if(t=1)/按朝向查找cout请输入朝向s;coutendl;cout楼号 单元号 房间号 平米单价 建筑面积 总价 朝向 户型 售出状态 业务员chaoxiang=s)coutsetw(6)setiosflags(ios:left)lou;/楼号coutsetw(7)setiosflags(ios:left)danyuan;/单元号coutsetw(7)setiosflags(ios:left)fangjian;/房间号coutsetw(9)setiosflags(ios:left)danjia;/平米单价coutsetw(9)setiosflags(ios:left)mianji;/建筑面积coutsetw(10)setiosflags(ios:left)zongjia;/总价coutsetw(7)setiosflags(ios:left)chaoxiang;/朝向coutsetw(12)setiosflags(ios:left)huxing;/户型coutsetw(9)setiosflags(ios:left)zhuangtai;/售出状态coutsetw(6)setiosflags(ios:left)renyuannext=NULL) break; p2=p1;p1=p1-next;elsep2-next=p1-next;p3=p1;if(p1-next=NULL) p2-next=NULL;delete p3;break;p2=p1;p1=p1-next;delete p3;coutendl;if(t=2)/按户型查找cout请输入户型s;coutendl;cout楼号 单元号 房间号 平米单价 建筑面积 总价 朝向 户型 售出状态 业务员huxing=s)coutsetw(6)setiosflags(ios:left)lou;/楼号coutsetw(7)setiosflags(ios:left)danyuan;/单元号coutsetw(7)setiosflags(ios:left)fangjian;/房间号coutsetw(9)setiosflags(ios:left)danjia;/平米单价coutsetw(9)setiosflags(ios:left)mianji;/建筑面积coutsetw(10)setiosflags(ios:left)zongjia;/总价coutsetw(7)setios
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 课件中插入AVI格式视频的方法
- 2025年彩票公司财务经理面试题库及答案
- 2025年航空乘务员专业技能考核试题及答案解析
- 2025年大学生安全常识测试题
- 机电知识培训的目的和意义
- 2025年宠物摄影摄像师高级面试常见问题集锦
- 2025年安全管理C卷模拟测试题解析
- 2025年农村扶贫助理招聘面试题及答案解析
- 学校教学常规检查课件
- 机电服务顾问基础知识培训课件
- DME糖尿病黄斑水肿
- DB1305∕T 45-2022 小麦品种冀麦325节水高产栽培技术规程(邢台市)
- 水利信息化水质监测系统单元工程质量验收评定表、检查记录
- 人教版六年级数学上册【全册教案】
- 合同法风险防范培训
- 中小学教师专业技术岗位聘任考核方案
- 2024-2025学年高三上学期《为什么要上一个好大学?》主题班会课件
- 职业技术学校物联网应用技术专业调研报告
- GB/T 43934-2024煤矿土地复垦与生态修复技术规范
- 2023年某技术有限公司技术规范
- 秋季传染病预防课件幼儿园
评论
0/150
提交评论