c语言个人通信录标准管理系统课程设计报告.doc
《c语言个人通信录标准管理系统课程设计报告.doc》由会员分享,可在线阅读,更多相关《c语言个人通信录标准管理系统课程设计报告.doc(32页珍藏版)》请在咨信网上搜索。
c语言个人通信录标准管理系统课程设计报告 高级语言程序设计报告 (个人通信录管理系统) 院 系: 通信与信息工程学院 班 级: 通信工程1104班 成 员: 杨文刚(1107020420) 李 岩(1107020421) 王皓升(1107020417) 罗 洋(1107020418) 沈 洋(1107020419) 王志旭(1107020422) 时 间: 2012年7月2日 基于链表的个人通信录管理系统课程设计任务书 课 程 设 计 情 况 课程设计名称 基于链表的个人通信录管理系统 指导教师姓名 职称 需学生数 6人 组长 杨文刚 成员 李岩、王皓升、罗洋、王志旭、沈洋 各 成 员 主 要 负 责 内 容 杨文刚 负责主体函数框架建立和函数模块整合 李 岩 负责程序的添加模块 王皓升 负责程序的删除模块 王志旭 负责程序的查找模块 罗 洋 负责程序的输出模块 沈 洋 负责程序的输入模块 程序的调试和测试由小组成员共同参与完成 课程设计的报告撰写由杨文刚、李岩完成 目 录 …………………………………………………1 …………………………………………………2 …………………………………………………3 ……………………………………………5 ………………………………………6 程序清单………………………………………………………………6 程序执行结果…………………………………………………………14 ………………………………………………20 问题描述 编写一C语言程序,其功能是建立一个基于链表的个人通信录管理系统,个 人通信录进行建立、输出、添加、查找及删除运行结果进行打印等相关操作。 问题分析 首先,选择合适的存储结构构造个人通信录,对该程序可以分为几个模块进行分析,每个模块在该程序中的作用进行了解。最后用设计连接图将各模块之间的联系连接起来,以方便我们更容易理解。 然后,该程序需要一个详细的设计流程图来表示各个步骤所完成的先后顺序,(如,对个人通信录进行添加,查找输出打印结果)。 最后,按流程图进行编写个人通信录的程序,输出结果,并将打印的结果显示出。 设计分析 本次实验设计主要是建立个人通信录,要实现个人通信录的建立,个人通信录的查找,个人通信录的添加及个人通信录的删除功能。. 设计需求上我们需要掌握以下几点: (1).设计部分 1. 写出本次实验的详细设计方案。 2. 画出该次程序的流程图。 3. 分析该次程序的程序清单,进行程序测试并输出运行结果。 4. 对该次程序中个函数的功能分析结果。 5. 对该次实验完成后有总结。 (2).设计大纲 1. 了解, 分析这次实验的主要问题。 2. 讨论解决问题的方案。 3. 分配组员的个人任务。 4. 进行各部分的整合、修改、完善。 5. 进行这次实验的总体报告实验总结。 程序设计组成框图 个人通信录 主函数模块 个人通信录查找模块 个人通信录删除模块 个人通信录添加模块 个人通信录输出模块 个人通信录建立模块 图1 流程图 开始 菜单选择 建立 输出 添加 查找 删除 信息输入 信息删除 信息查找 信息添加 信息输出 按身份证号查找 结束 否 否 否 否 否 是 是 是 是 是 模块功能说明 通信录建立模块 创建链表,并返回表头指针 { 创建新节点; while (判断读入编号) { 读入联系人信息; 保存到指定的域; 指针指向下一新节点; } } { 按指定格式输出通讯录表头信息; if(头指针不为空) { 按指定格式输出联系人信息; 记录联系人数; } else 通信录为空; } 通信录添加模块 { 新建节点; 屏幕提示输入要添加的联系人信息; 读入联系人信息; 按联系人编号升序排序; } 通信录删除模块 { 提示输入要删除的联系人编号; 读入编号信息; if(找到) {输出找到的联系人信息; 询问是否删除该联系人; } else 提示没有该联系人; } 通信录查找模块 { 提示输入要查找的联系人身份证号; 读入身份证号信息; If(找到) 显示查找到的联系人信息; else 提示没有该联系人; } 参照教材编写完程序的各个模块后,我们将各个模块和主函数整合,运行之后主要存在以下几个问题: 1. 程序输出信息部分不正确 运行程序,输入通信录中联系人信息后,程序输出的电话号码和身份证号信息错误,有时还会出现负数。经过查找发现在读入联系人信息时,这两项采用了长整型数据类型,但是长整型最大支持的值仍然小于电话号码和身份证号的值。我们换用字符串类型读入信息后为问题解决。 2. 结束联系人信息的输入(以数字0结束)存在问题 运行程序,我们在输入联系人信息完毕后是用数字0结束的,但是当我们输入完信息后,得将下一个联系人的所有信息全部输入为数字0时,程序才会结束输入。针对这个问题我们修改了输入模块的循环体顺序,让程序先判断输入的联系人编号是否为0,是0时结束输入,不是0时继续读入联系人信息。这样在我们结束输入时只需按一次0即可结束输入。 3. 联系人的查找存在问题 我们在查找(用身份证号)联系人时,当我们输入通信录中存在的联系人的身份证号时,程序能准确查找到该联系人;但当我们输入的身份证号信息在通信录中不存在时,程序会非法结束。为此,我们请教了老师,修改了if语句中的判断条件,程序能够在我们输入的身份证号信息不存在时正常提示“通信录中没有该联系人”,问题解决。 因为我们的程序是根据教材中的程序编写的,所以在调试过程中,程序没有出现大的错误,在模块连接上也没有问题,只是有一些输入输出以及一些循环体上的错误。 程序清单 /*主控菜单程序*/ #include "" #include "" #include "" struct per /*定义结构体类型*/ { long int num; char name[20]; char tel[12]; char mail[30]; char add[50]; long int mnum; char id[18]; struct per *next; }; struct per *jianli(); /*声明建立通信录函数*/ void shuchu(struct per *head); /*声明输出通信录函数*/ struct per *tianjia(struct per *head); /*声明添加联系人函数*/ struct per *shanchu(struct per *head); /*声明删除联系人函数*/ struct per *chazhao(struct per *head); /*声明查找联系人函数*/ struct per *head=NULL; void main() /*主函数*/ { int select; int pass1; int pass=123456; printf("\n欢迎使用个人通信录管理系统,请输入登录密码:"); scanf("%d",&pass1); if(pass==pass1) { printf("\n登录成功!\n\n"); do{ printf("\n\t***************** 欢迎进入个人通信录管理系统 ******************\n"); /*主控菜单*/ printf("\n\t ----------------->> 1: 建 立 通 信 录 <<-----------------"); printf("\n\t ----------------->> 2: 输 出 通 信 录 <<-----------------"); printf("\n\t ----------------->> 3: 添 加 联 系 人 <<-----------------"); printf("\n\t ----------------->> 4: 删 除 联 系 人 <<-----------------"); printf("\n\t ----------------->> 5: 查 找 联 系 人 <<-----------------"); printf("\n\t ----------------->> 0: 退 出 系 统 <<-----------------\n"); printf("\n\t***************************************************************\n"); printf("\n\t请选择(0---5):"); scanf("%d",&select); printf("\n"); switch(select) /*对应模块函数*/ { case 1: head=jianli();break; case 2: shuchu(head);break; case 3: head=tianjia(head);break; case 4: head=shanchu(head);break; case 5: head=chazhao(head);break; case 0: break; default: printf("您的输入有误,请重新输入(0---5):\n"); } }while(select!=0); } else printf("\n对不起,您输入的密码不正确,请按任意键退出程序!!!\n\n"); } /*建立通信录函数*/ struct per *jianli() /*创建链表,并返回表头指针*/ { struct per *head; /*表头*/ struct per *p1; /*新建节点*/ struct per *p2; /*表尾节点*/ long int num1; char name1[20]; char tel1[12]; char mail1[30]; char add1[50]; long int mnum1; char id1[18]; head=NULL; /*无任何节点,表头指向空*/ printf("请输入联系人编号、姓名、电话、身份证号、、地址及邮编(用空格分隔,用0结束)\n"); scanf("%d",&num1); while(num1!=0) /*假设num=0表示输入结束*/ { scanf(" %s %s %s %s %s %d",name1,tel1,id1,mail1,add1,&mnum1); /*读入第一个联系人的信息*/ p1=(struct per *)malloc(sizeof(struct per)); /*新建一个节点*/ p1->num=num1; /*存入联系人的信息*/ strcpy(p1->name,name1); strcpy(p1->tel,tel1); strcpy(p1->id,id1); strcpy(p1->mail,mail1); strcpy(p1->add,add1); p1->mnum=mnum1; p1->next=NULL; /*将next域置为空,表示尾节点*/ if(head==NULL) head=p1; /*第一个新建节点是表头*/ else p2->next=p1; /*原表尾的下一个节点是新节点*/ p2=p1; /*新建节点成为表尾*/ scanf("%d",&num1); } return head; /*返回表头指针*/ } /*输出通信录函数*/ void shuchu(struct per *head) { struct per *p; int n=0; /*统计节点数,即联系人数*/ printf("\n\t*******************通*******信*******录*******************\n"); printf("\n%-5s%-12s%-12s%-19s%-17s%-9s%-7s\n","编号","姓名","电话号码","身份证号","","地址","邮编"); if(head!=NULL) { for(p=head;p!=NULL;p=p->next) /*如果到达尾节点退出循环,否则继续*/ { printf("%-5d%-12s%-12s%-19s%-17s%-9s%-7d\n",p->num,p->name,p->tel,p->id,p->mail,p->add,p->mnum); n++; } printf("联系人总数:%d\n\n",n); } else printf("\n对不起,该通信录中没有任何联系人!\n\n"); } /*添加联系人函数*/ struct per*tianjia(struct per*head) { struct per*p; struct per*p1; struct per*p2; p2=head; p=(struct per*)malloc(sizeof(struct per)); /*新建节点p*/ printf("请输入要添加的联系人的编号、姓名、电话、身份证号、、地址、邮编:\n"); scanf("%d %s %s %s %s %s %d",&p->num,p->name,p->tel,p->id,p->mail,p->add,&p->mnum); printf("成功添加联系人%s !\n",p->name); if(head==NULL) { head=p; p->next=NULL; } else { while((p->num>p2->num)&&(p2->next!=NULL)) /*查找添加位置*/ { p1=p2; p2=p2->next; } if(p->num<=p2->num) /*从小到大排列,添加至表内*/ { if(p2==head) { head=p; p->next=p2; } else { p1->next=p; p->next=p2; } } else /*添加至表尾*/ { p2->next=p; p->next=NULL; } } return(head); } /*删除联系人函数*/ struct per * shanchu(struct person*head) { struct per *p2; struct per *p1; int num1,n; printf("请输入要删除的联系人编号:"); /*根据输入信息查找联系人*/ scanf("%d",&num1); if(head==NULL) { printf("\n通讯录为空\n\n"); return(head); } p2=head; while(num1 != p2-> num && p2->next !=NULL) { p1=p2; p2=p2->next; } if(num1==p2->num) { printf("\n成功查询到该联系人!\n"); printf("\n%-5s%-12s%-12s%-19s%-17s%-9s%-7s\n","编号","姓名","电话号码","身份证号","","地址","邮编"); printf("%-5d%-12s%-12s%-19s%-17s%-9s%-7d",p2->num,p2->name,p2->tel,p2->id,p2->mail,p2->add,p2->mnum); printf("\n确定删除? 1确定 0取消 "); scanf("%d",&n); switch(n) { case 1: {if(p2==head) head=p2->next; else p1->next=p2->next; free(p2); printf("\n成功删除编号为%ld的联系人!\n\n",num1);}break; case 0: printf("\n您取消了删除任务,联系人未被删除!\n"); break; } } else printf("\n对不起,该通信录中没有任何联系人!\n\n"); return(head); } /*查找函数*/ struct per *chazhao(struct per *head) { struct per*p2; char id1[20]; printf(" 请输入要查找的联系人身份证号:\n"); scanf("%s",id1); if(head==NULL) { printf("\n通讯录为空\n\n"); return(head); } p2=head; while (p2) { if(strcmp(p2->id,id1)==0) { printf("\n成功查询到该联系人!\n"); printf("\n%-5s%-12s%-12s%-19s%-17s%-9s%-7s\n","编号","姓名","电话号码","身份证号","","地址","邮编"); printf("%-5d%-12s%-12s%-19s%-17s%-9s%-7d\n",p2->num,p2->name,p2->tel,p2->id,p2->mail,p2->add,p2->mnum); break; } p2=p2->next; } if(!p2) printf("\n对不起,该通信录没有该联系人!\n\n"); return (head); } 程序执行结果 密码登录界面 密码输入错误界面 成功登录主界面 建立通信录 输出通信录 添加联系人 添加后输出通信录 成功查找联系人 找不到联系人时界面 删除询问界面 确认后成功删除联系人 通过这次的课程设计使我们充分了解了个人通信录的建立、输出、添加、删除、查找的基本原理,并可以编写出其程序。虽然说程序不是很完美的,但是总体上完成了老师的要求,当然这只能相对于我们这些初学者来说。除了课本上仅有的知识外,我们还借用了一些其他书上比较好的算法思想,以至于让我们的课程设计更加完美。 在这次课程设计中,让我们深知仅仅掌握课本上的知识是远远不够的。在刚开始编程时,让我们感觉到自己不知道应该从哪里下手。在操作时,常常会遇到一些棘手的问题难以解决,但经过我们组员的不断思考、共同努力,尝试着去更改出现问题的程序,直至程序可以正常运行输出。开始很困难,但在老师和同学们的帮助下,我们了解了很多操作,使后面变得更容易操作。 程序设计过程中,小组中的各成员快速行动,积极配合,分工合作,在完成了各自的函数模块程序的编写后,有积极参与程序的调试与测试,并快速的发现和解决了问题,过程中遇到了查找模块的问题,我们请教了老师,在老师的帮助下,我们解决了查找模块的问题。至此,我们的程序能够保证成功并且正确的运行。 参考文献 《C程序设计(第二版)》 谭浩强 清华大学出版社 《C语言程序设计》 田祥松 西安电子科技大学出版社 《C语言课程设计》 黄明等 电子工业出版社 《C语言时尚编程百例》 网冠科技 机械工业出版社 《标准C机能百练》 焦 华 中国铁道出版社- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 个人 通信 标准 管理 系统 课程设计 报告
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文