C++课程设计电话簿管理.doc
《C++课程设计电话簿管理.doc》由会员分享,可在线阅读,更多相关《C++课程设计电话簿管理.doc(20页珍藏版)》请在三一办公上搜索。
1、Visual C+课程设计实验报告题目:电话薄管理班级:07102003学号:0710200310姓名: 指导老师: 2008年9月实验题目: 5-5 电话薄管理一、 课程设计要求: 功能介绍:一个电话薄管理小程序。利用文本文件存储电话薄数据,具有添加、删除、显示和查询联系人号码的功能。(1) 将电话薄数据和相应的函数封装在类中,改写程序使之结构化。(2) 增加记录修改功能,能选择修改用户的姓名、电话。(3) 增加录入时间的显示及存储。(4) 增加缺省的查询方式,即查询时只输入姓名的首字母,所有符合这一条件的电话资料均在屏幕上显示。平定难易等级:A级。二、 程序设计思想(相关问题解决办法):类
2、 封装成类是首先遇到的问题,我根据课程设计书上的提示,通过看书和与同学讨论,最后比较清楚地明白了类的封装方法。我在封装时,在类中定义了一些内联函数,并且把函数都定义为公有成员,这样可以方便类外的函数使用成员数据。书上的参考程序与我的稍有不同。增加时间 这个是通过互联网学到的,利用time.h。3) 增加修改功能 我定义了 friend_node:modify_record 函数,用来修改用户的姓名、电话。在函数中,我运用了if-else,switch等语句并对函数进行了重载。并且本程序可以选择修改,姓,名,电话。首字母查询 这是一个比较难解决的问题,我使用了与全名查找基本相同的函数,我只要求姓
3、相同,全名查找要求姓和名全部相同。我在这个的解决上还存在一些问题,这证明程序还是不够完善。这说明我对指针的使用还不够好。三、 课程设计心得:本来打算选计算器,后来觉得计算器编起来没什么意思,就换成了这个难一点儿的电话薄管理。在程序编写过程中,我发现,不只是难了一点儿。但是,有难度才有挑战,才有乐趣,不是么?看到源程序,立马被其拥有的函数的数量震撼了。把它们封装起来费了我不少精力。但是,看着它们由零散的函数变为整齐的类,就如同看到C语言向C+语言进化。课程还提出了要增加时间单元。在VB里面,只需要把一个小钟表图标拖进来就可以了,而在C+里面,我尚且不知如何操作。最后通过互联网,才算学会在C+中调
4、用时间单元。也算是学了一招吧。通过这次C+的课程设计,我的知识得到了巩固,同时也学到了很多新知识。我意识到,我们不应是为了编程而编程,而是为了解决问题而编程。编出来的程序能够为我们服务,程序才有意义。四、 以下是我所编写的程序源代码及相关注解: /*第5题电话簿管理-源代码及关键源代码注解如下:*/PhoneBook 1.0 By Mark Miller #include#include#include#include#include#include#include/全程结构及变量class friend_node /类类型定义,包括:姓、名和电话号码 tm * CurrentTime;/定义
5、时间指针 char last_name20;/姓 char first_name15;/名 char phone_num12;/电话号码 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_n
6、ode *position_insertion_point(char lastname20);/寻找节点插入位置 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();/删除链首 void delet
7、e_end_of_list(friend_node *previous_ptr);/删除链尾 void delete_from_middle_of_list(friend_node *previous_ptr);/删除链表中一节点 int verify_delete();/确认是否删除 void delete_node(friend_node *previous_ptr);/删除一节点 void delete_list();/删除链表 void friend_node:jqsearch_by_name(); void search_by_name();/精确查找某一记录 void modify
8、_record();/修改记录 void write_list_to_file();/将链表写入文件 void load_list_from_file();/从文件中提取链表数据 void help_me();/帮助文件 void welcome(); friend istream& operator(istream& ,friend_node&);/重载函数 ; friend_node *head_ptr; /全程变量,链头指针 friend_node *current_ptr; /全程变量,用于指明当前节点在链表中的位置 friend_node *tail_ptr;/全程变量 friend
9、_node *temp_ptr;/主函数 void friend_node:welcome() coutendlendlendlendlendlendlendlendlendlendl; cout tt 欢迎使用电话簿管理程序 完美中文版 endlendl; cout tt 学号:0710200310 姓名:曹哲endlendl; cout ttt-按回车键继续-; char str20; cin.getline(str,20);/接受输入的任意字符 system(cls); /执行系统命令:cls-清屏 int choice; head_ptr = NULL; /初始化链首指针为空 load
10、_list_from_file(); / 从磁盘文件读取链表数据 do /主菜单显示 cout -电话簿管理-endl=endl; cout 增加新的电话簿记录nn; / cout 显示所有电话簿记录nn; / cout 查找确定电话簿记录(姓名精确查找)nn; cout 删除确定电话簿记录(通过姓氏查找)nn; cout 修改确定电话簿记录(姓名精确查找)nn;cout 帮助nn;cout 退出系统nn;cout 智能查询nn; cout choice;/输入选择 handle_choice(choice); / 调用handle_choice()函数根据选择作出反映,从而调动相应的功能函数
11、 while(choice != 7); / 返回菜单直到用户选择退出 void friend_node:handle_choice(int choice) /根据用户选择(choice)调用对应处函数 switch(choice) / 根据choice的值执行 case 1: add_record(); / 往链表中增加记录 break; case 2: display_list(); / 显示链表中所有记录 break; case 3: search_by_name(); /精确查找某一记录 break; case 4: delete_record(); /找到某记录后删除该记录 brea
12、k;case 5: modify_record();/修改记录 break;case 6: help_me();/帮助文件 break;case 8: jqsearch_by_name(); break;case 7: write_list_to_file(); /将数据存入文件并从内存中释放链表所占用的空间 if(head_ptr != NULL) delete_list(); break;default : / 任何其他的选择都将显示出错信息 cout 无效的选择!n; break; void friend_node:add_record() / 在链表中增加一个记录 friend_nod
13、e *new_rec_ptr; / 为新节点申请一指针 new_rec_ptr = new friend_node; / 为新节点分配内存并初始化指针使指向它 if(new_rec_ptr != NULL) / 若分配内存过程中没有出错,获取数据并使节点插入链表 system(cls); / 从用户那里得到姓名和电话号码. cin.ignore(20,n);/清空缓冲区,碰到字符串结束符就结束,从而接受新的字符 /以下程序中出现这一语句表同一意思 cout last_name,20); cin.ignore(20,n);cout first_name,15); cin.ignore(20,n)
14、; cout phone_num,15); cin.ignore(20,n); insert_node(new_rec_ptr);/插入新结点 time_t timedata=time(0); CurrentTime=localtime(& timedata);nYear=CurrentTime-tm_year+1900;nMonth=CurrentTime-tm_mon+1;nDay=CurrentTime-tm_mday;nHour=CurrentTime-tm_hour;nMinute=CurrentTime-tm_min; else / 若在分配内存中出错,显示警告信息并不要创建节点
15、cout next =new_rec_ptr-prev= NULL; /双向链表 else/链表不为空,又分3种情况 if(strcmp(new_rec_ptr-last_name, head_ptr-last_name) last_name);/确定应插入的位置 before_ptr = current_ptr; / 用指针保持跟踪节点 after_ptr = current_ptr-next; /在插入点位置的两边 if(after_ptr = NULL) / 若 after_ptr已达链尾,则将新节点插入链尾 add_node_to_end(new_rec_ptr); else /否则将
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+ 课程设计 电话簿 管理
链接地址:https://www.31ppt.com/p-2384470.html