C++课程设计---电话簿管理.doc

  1. 1、本文档共20页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C课程设计---电话簿管理

Visual C++ 课程设计实验报告 题目:电话薄管理 班级学号:0710200310 姓名: 指导老师: 2008年9月 实验题目: 5-5 电话薄管理 课程设计要求: 功能介绍:一个电话薄管理小程序。利用文本文件存储电话薄数据,具有添加、删除、显示和查询联系人号码的功能。 (1) 将电话薄数据和相应的函数封装在类中,改写程序使之结构化。 (2) 增加记录修改功能,能选择修改用户的姓名、电话。 (3) 增加录入时间的显示及存储。 (4) 增加缺省的查询方式,即查询时只输入姓名的首字母,所有符合这一条件的电话资料均在屏幕上显示。 平定难易等级:A级。 程序设计思想(相关问题解决办法): 类 封装成类是首先遇到的问题,我根据课程设计书上的提示,通过看书和与同学讨论,最后比较清楚地明白了类的封装方法。我在封装时,在类中定义了一些内联函数,并且把函数都定义为公有成员,这样可以方便类外的函数使用成员数据。书上的参考程序与我的稍有不同。 增加时间 这个是通过互联网学到的,利用time.h。 3) 增加修改功能 我定义了 friend_node::modify_record 函数,用来修改用户的姓名、电话。在函数中,我运用了if-else,switch等语句并对函数进行了重载。并且本程序可以选择修改,姓,名,电话。 首字母查询 这是一个比较难解决的问题,我使用了与全名查找基本相同的函数,我只要求姓相同,全名查找要求姓和名全部相同。我在这个的解决上还存在一些问题,这证明程序还是不够完善。这说明我对指针的使用还不够好。 课程设计心得: 本来打算选计算器,后来觉得计算器编起来没什么意思,就换成了这个难一点儿的电话薄管理。在程序编写过程中,我发现,不只是难了一点儿。但是,有难度才有挑战,才有乐趣,不是么? 看到源程序,立马被其拥有的函数的数量震撼了。把它们封装起来费了我不少精力。但是,看着它们由零散的函数变为整齐的类,就如同看到C语言向C++语言进化。 课程还提出了要增加时间单元。在VB里面,只需要把一个小钟表图标拖进来就可以了,而在C++里面,我尚且不知如何操作。最后通过互联网,才算学会在C++中调用时间单元。也算是学了一招吧。 通过这次C++的课程设计,我的知识得到了巩固,同时也学到了很多新知识。我意识到,我们不应是为了编程而编程,而是为了解决问题而编程。编出来的程序能够为我们服务,程序才有意义。 以下是我所编写的程序源代码及相关注解: /*第5题 电话簿管理--源代码及关键源代码注解如下:*/ //PhoneBook 1.0 By Mark Miller #includefstream.h #includeconio.h #includeiostream.h #includeiomanip.h #includestring.h #includestdlib.h #includetime.h //全程结构及变量 class friend_node //类类型定义,包括:姓、名和电话号码 { tm * CurrentTime;//定义时间指针 char last_name[20];//姓 char first_name[15];//名 char phone_num[12];//电话号码 int nYear,nMonth,nDay,nHour,nMinute;//定义 friend_node *next,*prev; char pause;//定义一字符型变量,用于接受输入的任意键 public: //函数原形说明 void handle_choice(int choice); //处理选择 void add_record();//增加记录 void insert_node(friend_node *new_rec_ptr);//插入节点 friend_node *position_insertion_point(char lastname[20]);//寻找节点插入位置 void make_node_new_head(friend_node *new_rec_ptr);//插入链首 void add_node_to_end(friend_node *new_rec_ptr);//插入链尾 void move_current_to_end();//使当前指针指向链尾 void display_list();//显示链表 void delete_record();//删除记录 void delete_head_of_list(

文档评论(0)

153****9595 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档