C语言实现个人通讯录管理系统
如何用c语言制作简易的个人通讯录管理系统?想必这是每一位初步学习c语言的同学需要解决的一个大问题。如何将这些数据类型不完全相同的数据元素存储并访问呢?采用结构体便能轻松解决这个问题!
创新互联公司从2013年开始,是专业互联网技术服务公司,拥有项目成都做网站、成都网站建设、成都外贸网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元谢通门做网站,已为上家服务,为谢通门各地企业和个人服务,联系电话:18982081108
#include#include #include #include struct stu //第一部分:声明结构体类型struct stu { char name[100];//姓名为字符串型 int xh;//学号为整形 int grade;//年级 char cel[15];//手机 char tel[50];//电话 char mail[50];//邮件 char add[100];//地址为字符串型 char post[15];//邮编 struct stu *next;//用指针处理链表,next是指针变量,指向结构体变量 }; struct stu *charu(struct stu *head,struct stu *q)//第二部分:插入函数(插入新结点) { struct stu *p; for(p=head;p->next!=NULL;p=p->next);//for(使p也指向head;当p为空文件时 ;p指向下一个结点) p->next=q; q->next=NULL; return head; } void search(struct stu *head) //第三部分:查找结点并输出 { struct stu *p; int a;//要查找学生的学号 if(head->next==NULL)//头文件为空时打印出的结果为"通讯录为空" printf("**********************************通讯录为空!!!*********************************\n\n\n"); else//头文件不为空时,开始查询学生的信息 { printf("\t输入要查询学生学号:"); scanf("%d",&a); for(p=head->next;p->next!=NULL;p=p->next)//for(使p也指向head;当p为空文件时 ;p指向下一个结点) { if(p->xh==a) //如果输入的学号和某个相同,输出以下的东西。 { printf(" 要查找的学生信息为:\n"); printf(" ★姓名:");puts(p->name); printf("\t学号: ");printf("%d",p->xh); printf("\t年级:");printf("%d\n",p->grade); printf("\t手机:");puts(p->cel); printf("\t电话:");puts(p->tel); printf("\t邮箱:");puts(p->mail); printf("\t地址");puts(p->add); printf("\t邮编:");puts(p->post); printf("\t查找成功!!!"); printf("\n\n\n"); break; } } if(p->xh==a) { printf(" 要查找的学生信息为:\n"); printf(" ★姓名:");puts(p->name); printf("\t年级:");printf("%d\n",p->grade); printf("\t手机:");puts(p->cel); printf("\t电话:");puts(p->tel); printf("\t邮箱:");puts(p->mail); printf("\t地址");puts(p->add); printf("\t邮编:");puts(p->post); printf("\t查找成功!!!"); printf("\n\n\n"); } else printf("no people have found!!!\n");//如果不符合,就输出没有找到 } } struct stu *del(struct stu *head) //第四部分:删除结点 { struct stu *p,*q; int a;//要删除学生的学号 if(head->next==NULL)// 头文件为空时,输出通讯录为空 printf("**********************************通讯录为空!!!*********************************\n\n\n"); else { printf("\t输入要删除学生学号:"); scanf("%d",&a); for(p=head,q=p->next;q->xh!=a&&q->next!=NULL;) { p=p->next; q=p->next; } if(q->xh==a) { p->next=q->next; free(q);//释放q,也就是删除q,在这里就是删除q(学号为a) printf("删除成功!!!\n"); } else printf("no people have found!!!");//如果不符合,就输出没有找到 } return head;//返回头文件 } struct stu *change(struct stu *head) //第五部分:修改结点内容 { int b,a,c; struct stu *p; if(head->next==NULL)// 头文件为空时,输出通讯录为空 printf("**********************************通讯录为空!!!*********************************\n\n\n"); else { printf(" 输入要修改学生学号:"); scanf("%d",&a); for(p=head->next;p!=NULL;p=p->next) { start:printf(" 输入想要修改什么?\n"); printf("\t\t\t 1:修改姓名\n"); printf("\t\t\t 2:修改学号\n"); printf("\t\t\t 3:修改年级\n"); printf("\t\t\t 4:手机\n"); printf("\t\t\t 5:电话\n"); printf("\t\t\t 6:邮件\n"); printf("\t\t\t 7:地址\n"); printf("\t\t\t 8:邮编\n"); printf(" 请输入你的选择:"); scanf("%d",&b); switch(b)//先通过学号找到该学生,然后用switch语句选择修改项,再用switch和goto语句实现是否循环 { case 1: printf("\t输入新姓名:"); scanf("%s",p->name);break; case 2:printf("\t输入新学号:"); scanf("%d",&p->xh);break; case 3: printf("\t输入新的年级:"); scanf("%d",&p->grade);break; case 4: printf("\t输入新的手机号:"); scanf("%s",p->cel);break; case 5: printf("\t输入新的电话号:"); scanf("%s",p->tel);break; case 6: printf("\t输入新的邮箱:"); scanf("%s",p->mail);break; case 7: printf("\t输入新的地址:"); scanf("%s",p->add);break; case 8: printf("\t输入新的邮编;"); scanf("%s",p->post);break; default: printf("输入操作错误,请重新输入:"); } printf("修改成功!!!\n"); printf(" 是否要修改其他项? 1:是 2:否\n"); printf(" 请输入你的选择:"); scanf("%d",&c); switch(c) //goto语句实现是否循环 { case 1:goto start; case 2:break; } } } return head; //返回头文件 } void printall(struct stu *head) //第六部分:输出全部通讯录 { struct stu *p=head->next; while(1) { if(p==NULL) { printf("**********************************通讯录为空!!!*********************************\n\n\n"); break; } else if(p->next==NULL) { printf(" ★姓名:");puts(p->name); printf("\t学号:");printf("%d\n",p->xh); printf("\t年级:");printf("%d\n",p->grade); printf("\t手机:");puts(p->cel); printf("\t电话:");puts(p->tel); printf("\t邮箱:");puts(p->mail); printf("\t地址:");puts(p->add); printf("\t邮编:");puts(p->post); printf("输出成功!!!\n"); printf("\n\n\n"); break; } else { printf(" ★姓名:");puts(p->name); printf("\t学号:");printf("%d\n",p->xh); printf("\t年级:");printf("%d\n",p->grade); printf("\t手机:");puts(p->cel); printf("\t电话:");puts(p->tel); printf("\t邮箱:");puts(p->mail); printf("\t地址:");puts(p->add); printf("\t邮编:");puts(p->post); printf("\n"); p=p->next; continue; } printf("输出成功!!!\n"); } } void sf(struct stu *head) //第八部分:释放结点退出系统 { struct stu *p=head ; printf("释放链表:\n"); while(p!=NULL) { head=head->next; free(p); p=head; } printf("释放链表成功!!!\n"); } int main()// 第九部分:主函数框架 { int cz;//操作符 struct stu *head,*q; head=(struct stu*)malloc(sizeof(struct stu));//动态链表malloc head->next=NULL;//使next指向下一个结点,next结点不放其他结点地址 system("color 1e");//修改dos窗口前背景色,用两个十六进制数表示 printf("班级: 姓名: 学号: 设计课题:个人通讯录管理系统\n"); printf("\n********************************C语言课程设计***********************************\n"); printf(" *******************★个人通讯录管理系统★*****************\n\n\n"); printf(" * 1:新建通讯录 *\n"); printf(" * 2:删除通讯录 *\n"); printf(" * 3:修改通讯录 *\n"); printf(" * 4:查询通讯录 *\n"); printf(" * 5:显示全部记录 *\n"); printf(" * 6:释放链表并结束程序 *\n"); printf(" *********************************************************\n"); start :printf("输入操作符1-6:");//"输入操作符1- scanf("%d",&cz); switch(cz)//switch语句 { case 1: q=(struct stu *)malloc(sizeof(struct stu)); printf("\t输入姓名:");scanf("%s",q->name); printf("\t输入学号:");scanf("%d",&q->xh); printf("\t输入年级:");scanf("%d",&q->grade); printf("\t手机号:");scanf("%s",q->cel); printf("\t家庭电话:");scanf("%s",q->tel); printf("\t输入电子邮件:");scanf("%s",q->mail); printf("\t通讯录地址:");scanf("%s",&q->add); printf("\t输入邮编:");scanf("%s",&q->post); charu(head,q); printf("插入成功!!!\n");break; case 2://删除 head=del(head);break; case 3: change(head);break;//修改学生信息 case 4: search(head);break;//查找结点head case 5: printall(head);break; //保存文件 case 6: //释放结点退出系统 sf(head); exit (0); default: printf("输入操作错误,重新"); //什么也不符合就"输入操作错误,重新" } goto start;//用goto语句实现循环操作 return 0; }
更多学习资料请关注专题《管理系统开发》。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。
本文标题:C语言实现个人通讯录管理系统
本文网址:http://hbruida.cn/article/ieppdj.html