C语言版用链表实现通讯录

合集下载

数据结构单链表通讯录设计

数据结构单链表通讯录设计

#include<stdio.h>#include<stdlib.h>#include<string.h>#define MAX 100//定义最大值typedef struct ENode{ int num;char Add[MAX];//地址char Name[MAX];//名字char telephone[MAX];//电话号码struct ENode *next;}ENode,*ENoteBook;ENoteBook CreatList(int n){ENoteBook P,Q,H;int i,x;for(i=1;i<=n;i++){P=(ENoteBook)malloc(sizeof(ENode));printf("请输入地址\n");gets(P->Add);gets(P->Add);printf("请输入名字\n");gets(P->Name);printf("请输入电话\n");gets(P->telephone);if(i==1) H=P;else Q->next=P;Q=P;}P->next=NULL;return H;}void InsertNoteBook(ENoteBook &L) {ENoteBook Q;Q=(ENoteBook)malloc(sizeof(ENode)); printf("现在输入插入元素信息\n"); printf("\n");printf("请输入地址\n");gets(Q->Add);//gets(Q->Add);// puts(Q->Add);printf("请输入名字\n");gets(Q->Name);printf("请输入电话\n");gets(Q->telephone);Q->next=L->next;//L->next=NULL;L->next=Q;printf("个人信息添加完成\n");}PrintNoteBook(ENoteBook &L)//打印函数{ENoteBook P;P=L;if(L!=NULL)printf("\t\t电子通讯录\n");printf("名字地址电话\n");do{printf("%s %s %s",P->Name,P->Add,P->telephone);printf("\n");P=P->next;}while(P!=NULL);}Deletemember(ENoteBook L){char str[MAX];ENoteBook P,Q;printf("请输入你要删除的名字\n");gets(str);P=L;while(P->next!=NULL){if (strcmp(str,P->next->Name)==0){P->next=P->next->next;goto end;}elseP->next=P->next->next;}printf("出错了!");end: printf("删除完成!\n");}void Checkmember(ENoteBook &L)//按名字{char str[MAX];ENoteBook Q;printf("请输入你要查找的名字\n");gets(str); gets(str);Q=L;while(Q->next!=NULL){ if (strcmp(str,Q->Name)==0){puts(Q->Name);puts(Q->Add);puts(Q->telephone);} else Q=Q->next;}printf("你出错了\n");}main(){ENoteBook q;int n;int i;eww: printf("欢迎使用电子通讯本管理软件\n");printf("----1. 创建信息----\n");printf("----2. 插入信息----\n");printf("----3. 打印信息----\n");printf("----4. 查找信息----\n");printf("----5 .删除信息----\n");printf("请选择您要执行的操作\n");scanf("%d",&i);switch(i){case 1: printf("请输入元素的个数\n");scanf("%d",&n);q=CreatList(n); goto eww; break;case 2: InsertNoteBook(q);goto eww; break;case 3: PrintNoteBook(q); goto eww; break;case 4: Checkmember(q);goto eww; break;case 5: Deletemember(q);goto eww;break;default:printf("操作出错\n");goto eww;}//Deletemember(q); }。

c语言实现通讯录管理系统(用链表实现)

c语言实现通讯录管理系统(用链表实现)

c语⾔实现通讯录管理系统(⽤链表实现)题⽬:通讯录(通过链表实现)设计并实现⼀个简易的通讯录软件,管理个⼈通讯记录。

⼀条通讯记录可包括:姓名、⼯作单位、⼿机、住宅电话、E-Mail、家庭住址等(可⾃⾏增删,但不可过少)。

该系统应实现以下基本功能:(1)增加新的通讯记录。

(2)删除已有的通讯记录。

(3)修改已有的通讯记录。

(4)浏览全部或指定(如指定姓名、⼯作单位等)的通讯记录。

(5)合理组织排列各项功能,界⾯可使⽤键盘操作。

(6)以⽂件的形式存储数据。

说明:⼤⼀时的c语⾔课设,⽤链表实现⼀个通讯录管理系统,为了美观好看,花了很多时间调整齐度,记录⼀下⼤⼀时的作业。

其主要功能是对通讯录可输⼊,显⽰,插⼊,删除,最难是可保存,这个学⽂件的时候不怎么会。

内容我⾃⼰弄了7个,名字,性别,⼯作单位,⼿机,住宅电话,E-Mail,家庭住址(其他太多其实都是⼀样的,就懒得加了)。

主要运⽤到对指针中的链表的功能和使⽤要⽐较扎实,分部列写就可以了。

实现图⽚:附上代码:1 #include <stdio.h>2 #include <string.h>3 #include <stdlib.h>4 typedef struct student5 {6char name[20];//名字7char wm[20];//性别8char work[100];//⼯作单位9char stel[20];//⼿机10char htel[20];//住宅号码11char mail[20];//E-Mail12char home[100];//家庭住址13struct student *next;14 }stu;15 stu *head;//头指针16void screen()//主菜单17 {18 printf("\n=======================================================\n");19 printf(" 欢迎来到通讯录管理系统\n\n");20 printf(" 1.输⼊数据 2.显⽰数据\n");21 printf(" 3.插⼊数据 4.删除数据\n");22 printf(" 5.查看数据 6.修改数据\n");23 printf(" 7.保存数据 8.返回主菜单\n");24 printf("\n~~~~~~输~~~~~~⼊~~~~~~9~~~~~~退~~~~~~出~~~~~~程~~~~~~序\n");25 }26void input()//输⼊数据27 {28int ans;//判断是否继续输⼊29 stu *p1,*p2;30 p1=(stu *)malloc(sizeof(stu));//申请内存来⽤31if(p1!=NULL)32 {33 printf("========输⼊数据========\n");34 head=p1;35while(1)36 {37 printf("名字:");38 scanf("%s",&p1->name);39 printf("性别:");40 scanf("%s",&p1->wm);41 printf("⼯作单位:");42 scanf("%s",&p1->work);43 printf("⼿机:");44 scanf("%s",&p1->stel);45 printf("住宅号码:");46 scanf("%s",&p1->htel);47 printf("E-Mail:");48 scanf("%s",&p1->mail);49 printf("家庭地址:");50 scanf("%s",&p1->home);51 printf("===================================\n");52 p2=p1;53 p1=(stu *)malloc(sizeof(stu));//申请下⼀个要⽤的空间54if(p1!=NULL)55 p2->next=p1;56 printf("请选择是否继续输⼊:1.继续 2.退出\n请选择:");//⽤户选择57 scanf("%d",&ans);58if(ans==1)//继续59continue;60else//退出61 {62 printf("========输⼊完毕========\n");63 p2->next=NULL;64free(p1);//将申请的的⽆⽤内存释放65break;66 }67 }68 }69 }70void look(stu *p1)//显⽰数据71 {72 printf("========显⽰数据========\n");73while(p1!=NULL)74 {75 printf("名字:%s\n",p1->name);76 printf("性别:%s\t",p1->wm);77 printf("⼯作单位:%s\t",p1->work);78 printf("⼿机:%s\t",p1->stel);79 printf("住宅号码:%s\t",p1->htel);80 printf("E-Mail:%s\t",p1->mail);81 printf("家庭住址:%s\n",p1->home);82 printf("=====================================\n");83 p1=p1->next;84 }85 printf("========显⽰完毕========\n");86 }87void insert()//插⼊数据88 {89int ans;//选择插⼊位置90char name[20];//插⼊者的名字91 printf("========插⼊数据========\n");92 stu *p1,*p2,*p3;93 p1=head;94 p3=(stu *)malloc(sizeof(stu));//申请内存95 p3->next=NULL;96 printf("请输⼊插⼊者的数据:\n");97 printf("名字:");98 scanf("%s",&p3->name);99 printf("性别:");100 scanf("%s",&p3->wm);101 printf("⼯作单位:");102 scanf("%s",&p3->work);103 printf("⼿机:");104 scanf("%s",&p3->stel);105 printf("住宅号码:");106 scanf("%s",&p3->htel);107 printf("E-Mail:");108 scanf("%s",&p3->mail);109 printf("家庭地址:");110 scanf("%s",&p3->home);111 printf("请选择插⼊位置:1.⾸位置插⼊ 2.尾部插⼊ 3.插到某⼈前⾯\n请选择:");112 scanf("%d",&ans);113switch(ans)114 {115case1://放到头指针116 p3->next=p1;117 head=p3;118break;119case2://放到尾部120while(p1->next!=NULL)121 p1=p1->next;122 p1->next=p3;123break;124case3://放到某⼈前⾯125 printf("请输⼊插到谁前⾯名字:");126 scanf("%s",name);127while(strcmp(name,p1->name)!=0)128 {129 p2=p1;130 p1=p1->next;131 }132 p2->next=p3;133 p3->next=p1;134break;135 }136 printf("========插⼊成功========\n");137 }138void deleted()//删除数据139 {140 stu *p1,*p2;141char name[20];//删除者名字142 printf("========删除数据========\n");143 printf("请输⼊要删除者的名字:");144 scanf("%s",name);145 p1=head;146if(head==NULL)//通讯录已经没数据了147 {148 printf("通讯录⾥什么也没有了。

通讯录链表

通讯录链表

#include <stdio.h>#include <stdlib.h>#include<string.h>struct node{ char name[20];char tel[12];char add[50];char qq[12];char num[15];struct node * next;};void new_record();void listall();void search();void revise();void Delete();void save();void get();struct node *head, *cur, *newp;void main(){head=(struct node *)malloc(sizeof(struct node));head->next=NULL;head=NULL;get();char a;printf("@欢迎使用通讯录@\n");printf("=======>1 进入通讯录\n");printf("=======>0 退出\n");scanf("%d",&a);while(a){printf("*********************通讯录**********************\n");printf("=======>1 添加新的数据\n");printf("=======>2 显示所有信息\n");printf("=======>3 查找信息\n");printf("=======>4 修改信息\n");printf("=======>5 删除信息\n");printf("=======>6 保存\n");printf("=======>0 退出\n");scanf("%d",&a);switch(a){case 1:{new_record();break;}case 2:{listall();break;}case 3:{search();break;}case 4:{revise();break;}case 5:{Delete();break;}case 6:{save();break;}case 0:{printf("**********谢谢使用,再见**********\n");break;}}}}void new_record(void){newp=(struct node * )malloc(sizeof(struct node));/* 开辟新结点*/newp->next=NULL;if(head==NULL) /* 原来为空表*/ head=newp;else{cur=head; /* 原来已有结点*/while(cur->next!=NULL)cur=cur->next;cur->next=newp;}cur=newp; /* 使cur指向新结点*/ getchar();printf("*****************添加新的通讯录****************\n");printf("输入姓名:"); /* 以下输入新结点数据*/gets(cur->name);printf("输入学号:");gets(cur->num);printf("输入电话:");gets(cur->tel);printf("输入QQ:");gets(cur->qq);printf("输入家庭住址:");gets(cur->add);cur->next=NULL; /* 新结点不再指向其它结点*/}void listall(void){int i=0;if(head==NULL){printf("通讯录为空\n");return;}cur=head; /* 使cur指向第一个结点*/do{printf("\n%d\n",++i); /*记录输出的个数*/printf("姓名: %s\n",cur->name); /*依次输出数据*/printf("学号: %s\n",cur->num);printf("电话: %s\n",cur->tel);printf("QQ: %s\n",cur->qq);printf("家庭住址: %s\n",cur->add);cur=cur->next;}while (cur!=NULL); /* 打印完最后一个结点不再打印*/}void search(void){char name[20];char num[15];char a;printf("**************请选择查找方式****************\n======>1.按姓名查找\n======>2.按学号查找\n"); /*选择查找方式*/scanf("%d",&a);if(a==1){printf("请输入要查找的名字\n"); /*按姓名查找*/scanf("%s",&name);cur=head;int i=0;int j=0;while(cur){if(strcmp(name,cur->name)==0) /*比较改结点是否有待查找的数据*/{j=1;printf("\n%d\n",++i); /*有显示出数据*/printf("姓名:%s\n",cur->name);printf("学号:%s\n",cur->num);printf("电话:%s\n",cur->tel);printf("QQ:%s\n",cur->qq);printf("地址:%s\n",cur->add);}cur=cur->next;}if(j==0) /*通讯录中无待查找的数据*/ printf("@没有查找的姓名@\n");printf("@搜送完毕@\n");}else if(a==2){printf("请输入要查找的学号\n"); /*按学号查找*/scanf("%s",&num);cur=head;int i=0;int j=0;while(cur){if(strcmp(num,cur->num)==0){j=1;printf("\n%d\n",++i);printf("姓名:%s\n",cur->name);printf("学号:%s\n",cur->num);printf("电话:%s\n",cur->tel);printf("QQ:%s\n",cur->qq);printf("地址:%s\n",cur->add);}cur=cur->next;}if(j==0)printf("没有查找的学号\n");printf("搜送完毕\n");}elseprintf("输入错误,请重新输入\n");}void revise(void){char name[20];int j=0;int i=1;printf("请输入要修改人的姓名\n");scanf("%s",&name); /*按姓名查找要修改的结点*/cur=head;while(cur){if(strcmp(name,cur->name)==0){j=1; /*先输出所有的信息,便于与要修改的地方对照*/printf("姓名:%s\n",cur->name);printf("学号:%s\n",cur->num);printf("电话:%s\n",cur->tel);printf("QQ:%s\n",cur->qq);printf("地址:%s\n",cur->add);printf("请输入要修改的信息\n");while(i){printf("1.修改学号\n2.修改电话\n3.修改QQ\n4.修改地址\n0.修改完成或退出修改\n");scanf("%d",&i);switch(i){ /*修改时一一对照*/case 1:{printf("原学号:%s\n",cur->num);printf("请输入修改的学号:");scanf("%s",cur->num);printf("修改完成\n");break;}case 2:{printf("原电话:%s\n",cur->tel);printf("请输入修改的电话:");scanf("%s",cur->tel);printf("修改完成\n");break;}case 3:{printf("原QQ:%s\n",cur->qq);printf("请输入修改的QQ:");scanf("%s",cur->qq);printf("修改完成\n");break;}case 4:{printf("原地址:%s\n",cur->add);printf("请输入修改的地址:");scanf("%s",cur->add);printf("修改完成\n");break;}case 0:break;default:printf("输入错误,请重新输入");}}}cur=cur->next; /*查找下一个结点是否有要修改的信息*/ }if (j==0)printf("无要修改的对象\n");}void Delete(void){struct node *p;char name[20];int i=1;cur=head;printf("输入要删除人的姓名\n"); /*按姓名查找要删除的结点*/scanf("%s",&name);if(strcmp(name,head->name)==0) /*判断是不是第一个结点就是要删除的*/ {head=head->next;i=0;printf("删除完成\n");}else{cur=head->next;while(i){if(strcmp(name,cur->name)==0) /*找到了要删除的结点*/{newp=head;while(i){if(newp->next==cur) /*找要删除结点的指针*/{newp->next=cur->next; /*略去该结点,删除完成*/i=0;printf("删除完成\n");break;}elsenewp=newp->next;}}elsecur=cur->next;}}if(i)printf("无要删除的姓名\n");}void save(){FILE *fp;fp=fopen("通讯录.txt","w+");while(head){fprintf(fp,"姓名:%s\t",head->name);fprintf(fp,"学号:%s\t",head->num);fprintf(fp,"电话:%s\t",head->tel);fprintf(fp,"QQ:%s\t",head->qq);fprintf(fp,"地址:%s\t",head->add);fprintf(fp,"\n");head=head->next;}fclose(fp);printf("保存完毕。

c语言双链表通讯录

c语言双链表通讯录

c语言双链表通讯录题目三:通讯录系统1.实验目的和意义:利用c语言编写通讯录系统,使我们更加熟练的掌握c语言及软件开发的基本步骤,进一步理解并掌握结构体和双链表的使用,初步掌握文件的调用。

该课题设计对学生来说是对这一学期有关c语言学习的一个评估,是将c语言应用于生活中,提高学生的动手能力。

该课题有利于让学生将课本上学习的零散的知识融会贯通、综合运用、强化知识体2.实验内容:1、当启动通讯录管理系统时读取通讯录文件2、进入主功能菜单3、创建联系人列表并保存修改后的通讯录4、删除创建的联系人并保存修改后的通讯录5、打印出保存后的通讯录当未创建通讯录时提示用户创建新的通讯录6、根据用户输入的联系人的首字母查找符合条件的联系人7、退出通讯录管理系统3.小组成员分工:小组讨论算法:全体成员编写程序:樊义,高杰林,曹仲生调试程序:陈伟杰漏洞修复及报告设计:陈伟杰4.设计要点:建立结构体并创建链表,添加删除节点,字符串的匹配。

设计功能选择函数,5.源程序:#include "stdio.h"#include "stdlib.h"#include "string.h"typedef struct message{char name[30];char number[20];char email[30];char adress[100];char qq[120];struct message *proir;struct message *next;} mess;mess *head=NULL;mess *p[100];int man=0;/////////////////////////////////////////////////////////////////// /////////// char menu();void add();void del();char del_menu();void del_name();void del_adress();void del_number();void del_email();void del_qq();void find();char find_menu();void find_name();void find_adress();void find_number();void find_email();void find_qq();void print();char print_menu();void print_time();void print_word();void file_save();/////////////////////////////////////////////////////////////////// ///////// //////////////////////////////////主函数int main(){FILE *fp=fopen("1.txt","r+");if(fp==NULL)printf("通讯录为空!!\n");else{fseek(fp,0,2);if(ftell(fp)==0)printf("通讯录为空!\n");else{mess *p2,*tmp;rewind(fp);head=(mess *)malloc(sizeof(mess));head->next=NULL;p[0]=head;while(feof(fp)==0){p2=(mess *)malloc(sizeof(mess));fscanf(fp,"%s%s%s%s%s",p2->name,p2->adress,p2->numb er,p2->email,p2->qq);tmp=head;while(tmp->next!=NULL)tmp=tmp->next;tmp->next=p2;p2->next=NULL;p2->proir=tmp;man++;p[man]=p2;p[man+1]=NULL;}man--;p2->proir->next=NULL;printf("数据读取完毕!\n");int flag=fclose(fp);if(flag!=0){printf("关闭文件失败!");return 0;} }}start:char i;i=menu();switch(i){case '1':add();break;case '2':del();break;case '3':find();break;case '4':print();break;case '5':file_save();return 0;case '6':return 0;}goto start;}/////////////////////////////////////////////////////////////////// /////////////////////////////////////// //////主菜单char menu(){char i;printf("---------------功能菜单---------------\n");printf(" | 1.录入信息\t 2.删除信息|\n");printf(" | 3.查找信息\t 4.显示信息|\n");printf(" | 5.保存并退出 6.退出\t |\n");printf("--------------------------------------\n");while(1){printf("请输入功能编号:");scanf("%s",&i);if('0'<i&&i<'7')< p="">return i;elseprintf("无效指令!");}}/////////////////////////////////////////////////////////////////// /////////////////////////////////////// //////录入函数void add(){mess *p1;p1=(mess *)malloc(sizeof(mess));printf("请输入姓名:\n");scanf("%s",&p1->name);printf("请输入地址:\n");scanf("%s",&p1->adress);printf("请输入手机号码:\n"); scanf("%s",&p1->number);printf("请输入邮箱:\n");scanf("%s",&p1->email);printf("请输入qq号码:\n");scanf("%s",&p1->qq);if(head==NULL){head=(mess *)malloc(sizeof(mess)); head->next=p1;p1->next=NULL;p1->proir=head;p[0]=head;man++;p[man]=p1;p[man+1]=NULL;}else{mess *p2=head->next;while(p2->next!=NULL)p2=p2->next;p2->next=p1;p1->next=NULL;p1->proir=p2;man++;p[man]=p1;p[man+1]=NULL;}printf("添加成功!通讯录内现有%d个联系人\n是否继续录入信息........",man);char ch;done:scanf("%s",&ch);if(ch=='n');else if(ch=='y') add();else {printf("无效指令!请重新输入:");goto done;}}/////////////////////////////////////////////////////////////////// /////////////////////////////////////// ///删除函数void del(){char i=del_menu();switch(i){case '1':del_name();break;case '2':del_adress();break;case '3':del_number();break;case '4':del_email();break;case '5':del_qq();break;case '6':break;}}////////////////////char del_menu(){char i;printf("---------------删除菜单---------------\n"); printf(" | 1.按姓名删除\n | 2.按地址删除\n"); printf(" | 3.按手机号码删除\n | 4.按邮箱删除\n"); printf(" | 5.按qq号删除\n | 6.返回主菜单\n"); printf("--------------------------------------\n"); while(1){printf("请输入功能编号:");scanf("%s",&i);if('0'<i&&i<'7')< p="">return i;elseprintf("无效指令!");}}///////////////////void del_name(){if(man==0)printf("通讯录为空!\n\n");else{char ch[30];int i=1;mess *p1=head->next;printf("请输入被删用户的姓名:\n");scanf("%s",ch);while(p1!=NULL){if(strcmp(p1->name,ch)==0){while(p[i]!=p1)i++;while(p[i]!=NULL){p[i]=p[i+1];i++;}p1->proir->next=p1->next;if(p1->next!=NULL)p1->next->proir=p1->proir;printf("此用户信息已删除!");printf("是否继续删除........");man--;char tmp;done: scanf("%s",&tmp);if(tmp=='n')break;else if(tmp=='y') {del();break;}else {printf("无效指令!请重新输入:");goto done;} } p1=p1->next;}if(p1==NULL){printf("查无此人!\n");printf("是否继续删除........");char tmp;a: scanf("%s",&tmp);if(tmp=='n');else if(tmp=='y') del();else {printf("无效指令!请重新输入:");goto a;}}}}/////////////////////void del_adress(){if(man==0)printf("通讯录为空!\n\n");else{char ch[30];int i=1;mess *p1=head->next;printf("请输入被删用户的地址:\n"); scanf("%s",ch);while(p1!=NULL){if(strcmp(p1->adress,ch)==0) {while(p[i]!=p1)i++;while(p[i]!=NULL){p[i]=p[i+1];i++;}p1->proir->next=p1->next;if(p1->next!=NULL)p1->next->proir=p1->proir; printf("此用户信息已删除!");printf("是否继续删除........");man--;char tmp;done: scanf("%s",&tmp);if(tmp=='n')break;else if(tmp=='y') {del();break;}else {printf("无效指令!请重新输入:");goto done;} } p1=p1->next;}if(p1==NULL){printf("查无此人!\n");printf("是否继续删除........");char tmp;a: scanf("%s",&tmp);if(tmp=='n');else if(tmp=='y') del();else {printf("无效指令!请重新输入:");goto a;}}}}/////////////////////////////void del_number(){if(man==0)printf("通讯录为空!\n\n");else{char ch[30];int i=1;mess *p1=head->next;printf("请输入被删用户的电话号码:\n");scanf("%s",ch);while(p1!=NULL){if(strcmp(p1->number,ch)==0){while(p[i]!=p1)i++;while(p[i]!=NULL){p[i]=p[i+1];i++;}p1->proir->next=p1->next;if(p1->next!=NULL)p1->next->proir=p1->proir;printf("此用户信息已删除!");printf("是否继续删除........");man--;char tmp;done: scanf("%s",&tmp);if(tmp=='n')break;else if(tmp=='y') {del();break;}else {printf("无效指令!请重新输入:");goto done;} } p1=p1->next;}if(p1==NULL){printf("查无此人!\n");printf("是否继续删除........");char tmp;a: scanf("%s",&tmp);if(tmp=='n');else if(tmp=='y') del();else {printf("无效指令!请重新输入:");goto a;}}}}/////////////////////void del_email(){if(man==0)printf("通讯录为空!\n\n");else{char ch[30];int i=1;mess *p1=head->next;printf("请输入被删用户的邮箱:\n"); scanf("%s",ch);while(p1!=NULL){if(strcmp(p1->email,ch)==0) {while(p[i]!=p1)i++;while(p[i]!=NULL){p[i]=p[i+1];i++;}p1->proir->next=p1->next;if(p1->next!=NULL)p1->next->proir=p1->proir; printf("此用户信息已删除!");printf("是否继续删除........");</i&&i<'7')<></i&&i<'7')<>。

南航 C语言课程设计 通讯录管理系统 链表实现

南航 C语言课程设计 通讯录管理系统 链表实现
3、处理了其他细节,降低误操作的可能性。如创建链表时判断链表是否为空并给 出提示,防止用户误操作(即将插入记录与创建电话簿两种功能严格区分,这能有效避免 未释放空间的产生)。又如,对于删除同名记录还判断是否同名但信息不同的情况,允许 用户自行决定是否删除。优化了用户界面的友好程度。
4、编程时尽量采用效率最高的链表算法。提交的源程序中(非报告中的程序)部 分函数代码后增添了多种效果等同的代码(注释掉了),报告中最终保留的所有涉及链表 操作的算法大多已实现遍历一次即可达成目的(时间复杂度 O(n))。
0
031220732 HQ C 语言课程设计报告
1、摘要
报告将详细描述“电话簿管理系统”的 C 语言实现方案,程序代码将以 C 语言形式 给出。报告将包括程序总体设计的介绍以及各子函数功能的说明,同时也包括在做课程设 计过程中的心得体会,最终将给出典型数据与测试流程。
2、题目描述与解决方案
2-1.题目描述
2、对于错误的数据,设计了相应的修改程序,主动提示可能需要修改的成员与当 前内容,并允许用户对某一字段进行修改(而不需要重新输入整条记录)。设计了 _Modify()函数实现上述功能。
3、设计了二级菜单用于实现上述功能的调用,同时设计了一些琐碎的小功能,如 改变软件背景与文字颜色的功能和“关 于”程序和彩蛋小游戏。设计了 ExtraFunction()实现上述功能(恢复数 据功能也在该函数内完成)。
图 1-二级菜Biblioteka 效果图3-4.已知的不足1、代码冗长,维护起来不如最精简版本容易。(可削减所有附加功能以解决) 2、输入输出细节处理过多,影响程序可读性。(可适当减少处理) 3、某些代码效率不高,如查错功能在数据规模极大时会极大拖累运行效率。 4、采用了批处理命令,只适合 WINDOWS 平台、DOS 平台,可移植性一般。 5、采用了在 C++中被认为是不安全的标准库函数,如 scanf 等。

链表实现通讯录

链表实现通讯录

#i n c l u d e<s t d i o.h>#include <malloc.h>#include <stdlib.h>#include <string.h>struct txl{char n[10];char name[10];char sex [10];char tele[12];char address[100];struct txl *next;};typedef struct txl TXL;typedef struct txl * link;enum result {exit_ok};void menu_select()//主菜单{printf(" 欢迎进入通讯录管理系统\n");printf("********************************\n");printf(" 1.联系人添加\n");printf(" 2.联系人删除\n");printf(" 3.联系人修改\n");printf(" 4.联系人查找\n");printf(" 5.联系人总览\n");printf(" 0.退出通讯录管理系统\n");printf("********************************\n");}void is_malloc_ok(link *new_node){if((*new_node) == NULL){printf("Malloc error!");exit(-1);}}void create_link(link *head){(*head) = (link)malloc(sizeof(TXL));is_malloc_ok(head);(*head)->next = NULL;}void create_new_node(link *new_node){int i;*new_node = (link)malloc(sizeof(TXL));is_malloc_ok(new_node);printf("请输入编号:\n");scanf("%s",&(*new_node)->n);printf("请输入姓名:\n");scanf("%s",&(*new_node)->name);printf("请输入性别:\n");scanf("%s",&(*new_node)->sex);printf("请输入联系电话:\n");scanf("%s",&(*new_node)->tele);printf("请输入家庭地址:\n");scanf("%s",&(*new_node)->address);printf("联系人添加成功!\n");}insert_new_node(link *new_node,link *head){(*new_node)->next = (*head)->next;(*head)->next = (*new_node);}void add_new_node(link *head){link new_node;create_new_node(&new_node);insert_new_node(&new_node,head);}void display(link *head){int i = 1;link p = NULL;if((*head)->next == NULL){printf("通讯录为空!\n");return;}else{p = (*head)->next;while(p != NULL){printf("第%d个联系人的信息如下:\n",i);printf("序号:%s\n",p->n);printf("姓名:%s\n",p->name);printf("性别:%s\n",p->sex);printf("联系电话:%s\n",p->tele);printf("家庭地址:%s\n\n\n",p->address);p = p->next;i++;}}}void find(link *head){char n1[10],name1[10],tele1[12],address1[100];int i;link xz = (*head)->next;printf("1.按编号查询\n");printf("2.按姓名查询\n");printf("3.按联系电话查询\n");printf("请输入您想选择的查询方式:\n");scanf("%d",&i);if(i == 1){printf("请输入您想查询的编号:\n");scanf("%s",n1);if(xz == NULL){printf("通讯录为空!\n");return;}while(xz !=NULL){if(strcmp(xz->n,n1) == 0){printf("您想查询的联系人的信息如下:\n");printf("编号:%s\n",xz->n);printf("姓名:%s\n",xz->name);printf("性别:%s\n",xz->sex);printf("联系电话:%s\n",xz->tele);printf("家庭地址:%s\n",xz->address);return;}elsexz = xz->next;}printf("通讯录中无此人!\n");}if(i == 2){printf("请输入您想查询的姓名:\n");scanf("%s",name1);if(xz == NULL){printf("通讯录为空!\n");return;}while(xz != NULL){if(strcmp(xz->name,name1) == 0){printf("您想查询的联系人的信息如下:\n");printf("编号:%s\n",xz->n);printf("姓名:%s\n",xz->name);printf("性别:%s\n",xz->sex);printf("联系电话:%s\n",xz->tele);printf("家庭地址:%s\n",xz->address);return;}elsexz = xz->next;}printf("通讯录中无此人!\n");return;}if(i == 3){printf("请输入您想查询的联系电话:\n");scanf("%s",tele1);if(xz == NULL){printf("通讯录为空!\n");return;}while(xz != NULL){if(strcmp(xz->tele,tele1) == 0){printf("您想查询的联系人的信息如下:\n");printf("编号:%s\n",xz->n);printf("姓名:%s\n",xz->name);printf("性别:%s\n",xz->sex);printf("联系电话:%s\n",xz->tele);printf("家庭地址:%s\n",xz->address);return;}elsexz = xz->next;}printf("通讯录中无此人!\n");return;}}void change(link *head){int a;link p = (*head)->next;char name1[10];char tele1[12];char address1[100];printf("请输入您想修改的联系人信息:\n");printf("1.姓名\n");printf("2.联系电话:\n");printf("3.家庭地址:\n");scanf("%d",&a);if(a == 1){printf("请输入原姓名:\n");scanf("%s",name1);while( p != NULL){if((strcmp(p->name,name1)) == 0){printf("请输入新的姓名:\n");scanf("%s",&p->name);printf("联系人修改成功!\n");return;}elsep = p->next;}printf("通讯录中没有此人!\n");return;}if(a == 2){printf("请输入原联系电话:\n");scanf("%s",tele1);while(p != NULL){if((strcmp(p->tele,tele1)) == 0){printf("请输入新的联系电话:\n");scanf("%s",&p->tele);printf("联系人修改成功!\n");return;}elsep = p->next;}printf("通讯录中没有此人!\n");}if(a == 3){printf("请输入原家庭地址:\n");scanf("%s",address1);while(p != NULL){if((strcmp(p->address,address1)) == 0){printf("请输入新的家庭地址:\n");scanf("%s",&p->address);printf("联系人修改成功!\n");return;}elsep = p->next;}printf("通讯录中没有此人!\n");}}void delete(link *head){link p1 = (*head);link p2 = (*head)->next;char name1[10];printf("请输入您要删除的联系人姓名:\n");scanf("%s",name1);if((*head)->next = NULL){printf("通讯录为空!\n");return;}while((strcmp(p2->name,name1) != 0)&&p2->next !=NULL) {p1 = p2;p2 = p2->next;}if(p2->next == NULL ){if(strcmp(p2->name,name1) == 0){p1->next = NULL;printf("该联系人已删除!\n");free(p2);}else{printf("通讯录中无此人!\n");}}else{p1->next = p2->next;free(p2);}}void exit_link(){printf("************************\n");printf(" 再见!\n");exit(exit_ok);}void switch_function(link *head){int num;scanf("%d",&num);switch(num){case 1:add_new_node(head); break;case 2:delete(head);break;case 3:change(head);break;case 4:find(head);break;case 5:display(head);break;case 0:exit_link();break;default:printf("该功能不存在,请重新输入!");break;}}int main(){link head = NULL;link new_node = NULL;create_link(&head);menu_select();while(1){printf("请输入您想要的功能:\n");switch_function(&head);}return 0;}。

链表做的通讯录(有要求和源代码宁波工程学院)

链表做的通讯录(有要求和源代码宁波工程学院)

三、实验内容1、通讯录设计设计一个班级同学的通讯录,要求如下:✓通讯录中每个同学的信息包含以下内容:学号(id)、姓名(name)、电话号码(tel)。

如果需要更多其他信息,请自行添加。

✓程序主菜单包含以下几个功能:(1)添加记录:通过键盘输入信息,添加一条通讯录记录。

(2)删除记录:通过键盘输入学号,删除该学号的记录。

(3)输出记录:输出通讯录全部记录。

(4)按姓名查找:通过键盘输入姓名,输出该同学的所有信息。

(5)保存记录:把通讯录中所有的记录保存到文件中。

(6)清空记录:删除通讯录中的全部记录,并删除文件。

(7)退出提示:✓程序启动时应判断是否存在记录文件,如果存在,则读取每条记录到链表中。

✓用户选择并完成主菜单某功能后,除了退出程序,应该返回主菜单。

✓添加一条记录时,插入到链表的尾部。

✓查找、删除记录时,如果该记录不存在,则应该输出不存在的提示。

✓添加记录、删除记录时不需要写文件。

✓保存记录时,用覆盖写文件的方法。

(或者先删除原文件,再保存全部记录信息)✓各个功能模块写成函数,由主函数调用。

选做:✓主菜单增加一个排序功能选项,可以按照学号从小到大进行排序。

排序方法可以用冒泡排序或者插入排序。

#include<stdio.h>#include<malloc.h>#include<string.h>#include<stdlib.h>#include<string.h>FILE *fp; //文件指针typedef struct lnode{int id;char name[10];int tel;struct lnode *next;}stud;void Inside(stud *&s,int ID,char *NAME,int TEL); bool Delete(stud *&s,int ID);void Output(stud *s);bool Sereachname(stud *&s,char *NAME); void Memory(stud * s);void Write(stud * s);void Empty(stud *&s);void Ini(stud *&s);void Start(stud *s);int main(){int n,ID,TEL;char NAME[10];stud *s;Ini(s);Start(s);printf("*****************************1.添加记录\t2.删除记录*****************************\n");printf("*****************************3.输出记录\t4.按姓名查找***************************\n");printf("*****************************5.保存记录\t6.清空记录*****************************\n");printf("*****************************7.退出\t***************************************\n");while(~scanf("%d",&n)){if(n>=1&&n<=6){switch(n){case 1:{printf("输入学号、姓名、电话\n");scanf("%d%s%d",&ID,&NAME,&TEL);Inside(s,ID,NAME,TEL);break;}case 2:{printf("请输入“学号”\n");scanf("%d",&ID);Delete(s,ID);break;}case 3:{Output(s);break;}case 4:{printf("请输入“姓名”\n");scanf("%s",&NAME);Sereachname(s,NAME);break;}case 5:{Memory(s);printf("保存成功\n");break;}case 6:{Empty(s);break;}}}if(n==7){printf("***********谢谢使用************\n");break;}printf("*****************************1.添加记录\t2.删除记录*****************************\n");printf("*****************************3.输出记录\t4.按姓名查找***************************\n");printf("*****************************5.保存记录\t6.清空记录*****************************\n");printf("*****************************7.退出\t***************************************\n");}return 0;}void Ini(stud *&s){s=(stud *)malloc(sizeof(stud));s->next=NULL;}void Inside(stud * &s,int ID,char *NAME,int TEL) //输入记录{stud *r,*t=s;while(t->next!=NULL){t=t->next;}r=(stud *)malloc(sizeof(stud));r->id=ID;strcpy(r->name,NAME);r->tel=TEL;r->next=NULL;t->next=(stud *)malloc(sizeof(stud));t->next=r;}bool Delete(stud * &s,int ID) //删除记录{stud *r=s,*q,*pre=s;r=r->next;while(r!=NULL && r->id!=ID) {pre=pre->next;r=r->next;}if(r==NULL){printf("该记录不存在\n"); return false;}else{q=pre->next;pre->next=q->next;free(q);printf("删除成功\n");return true;}void Output(stud *s) //输出记录{if(s!=NULL)s=s->next;if(s!=NULL){while(s!=NULL){ printf("学号\t姓名\t电话\n");printf("%d\t",s->id);printf("%s\t",s->name);printf("%d\n",s->tel);s=s->next;}}else{printf("该通讯录为空\n");}bool Sereachname(stud *&s,char *NAME) //按名字查找{stud *p,*pre=s;p=s->next;while(p!=NULL&&(strcmp(p->name,NAME))){pre=pre->next;p=p->next;}if(p==NULL){printf("该学生不存在\n");return false;}else{printf("学号\t姓名\t电话\n");printf("%d\t",p->id);printf("%s\t",p->name);printf("%d\n",p->tel);return true;}}void Memory(stud * s) //{fp=fopen("d:\\in.txt","w"); //数据保存到文件中if(s!=NULL)s=s->next;while(s!=NULL){fprintf(fp,"%d\t%s\t%d\n",s->id,s->name,s->tel);//写入文件s=s->next;}fclose(fp);}void Empty(stud * &s) //清空记录{stud *p=s,*q=s;p=p->next;if(p!=NULL)q=p->next;while(q!=NULL){free(p);p=q;q=p->next;}free(p);s->next=NULL;printf("该通讯录已空\n");}void Start(stud *s) // 初始化和载入文件中数据{system("color 09"); //屏幕、字体颜色char NAME[10];int ID,TEL;fp=fopen("d:\\in.txt","a"); //从文件中加载数据,如果没有该文件则新建fclose(fp);fp=fopen("d:\\in.txt","r");while(fscanf(fp,"%d%s%d",&ID,NAME,&TEL)!=EOF) //从文件中读入数据Inside(s,ID,NAME,TEL);fclose(fp);}宁波工程学院计科12-1。

用链表的方法实现一个简单的电话本

用链表的方法实现一个简单的电话本

用链表的方法实现一个简单的电话本:#include <iostream>#include <stdlib.h>#include <fstream>#include <iomanip>#include <string>using namespace std;// 电话本单个成员class undergraduate{private:string name;// 姓名string no;// 电话public:undergraduate *next_ptr;// 指向下一个成员的链结undergraduate (const string &n=0, const string &t=0);// 构造undergraduate (undergraduate &p); // 拷贝构造函数int FindName(const string &str); // 找到该成员是返回1, 否则返回0string& GetTel() {return tel_num;}; // 得到电话号码string& GetName() {return name;};// 得到名字};// 构造函数undergraduate:: undergraduate (const string &n, const string &t){name = na;no =n ;next_ptr = NULL;}// 拷贝构造函数undergraduate:: undergraduate (undergraduate &p){name = ;no = p.no;next_ptr = p.next_ptr;}// 找到该成员int undergraduate::FindName(const string &str){if (str == name){return 1;}else{return 0;}}// 电话本class PhoneBook{private:undergraduate * head_ptr;public:PhoneBook();// 构造void Create(undergraduate new undergraduate);// 添加记录void Delete(const string &deletename);// 删除记录void DeleteAll(); // 删除所有记录void Find(const string &fname);// 查找记录void Save();// 保存到文件void Load();// 从文件读取void PrintAll();// 全部打印~PhoneBook();// 析构};// 构造函数PhoneBook::PhoneBook(){head_ptr = NULL;}// 创建新记录void PhoneBook::Create(undergraduate new undergraduate) {if (head_ptr == NULL)// 若为空链表直接添加记录{head_ptr = new Person (new undergraduate);}else{Person *p = head_ptr;while (p -> next_ptr != NULL)// 找到尾节点为pp = p -> next_ptr;}p -> next_ptr = new undergraduate (newundergraduate);// 添加记录}cout << " 已添加新纪录" << endl;}// 删除记录void PhoneBook::Delete(const string &deletename){if (head_ptr == NULL)// 头为空{cerr << " 还没有任何记录!" << endl;system("pause");}else if (head_ptr -> next_ptr == NULL) // 只有头{if(head_ptr -> FindName (deletename)){delete head_ptr;head_ptr = NULL;cout << " 已成功删除" << deletename << endl;}else{cerr << " 未找到这条记录!" << endl;system("pause");}}else // 其他情况{Person *last = head_ptr;// 记录上一个链节Person *p = last -> next_ptr;if(last -> FindName (deletename)) // 删头{delete last;head_ptr = p;cout << " 已成功删除" << deletename << endl;else// 其他情况{while (p != NULL && !(p -> FindName (deletename)))// 遍历{last = last -> next_ptr;p = last -> next_ptr;}if (p != NULL) // 找到了{last -> next_ptr = p -> next_ptr;delete p;cout << " 已成功删除" << deletename << endl;}else // 没找到{cerr << " 未找到这条记录!" << endl;system("pause");}}}}// 删除所有记录void PhoneBook::DeleteAll(){if (head_ptr == NULL)// 头为空{cerr << " 还没有任何记录!" << endl;system("pause");}else{Person *temp = head_ptr;while (head_ptr != NULL){head_ptr = head_ptr -> next_ptr;delete temp;temp = head_ptr;}head_ptr=NULL;cout << " 已删除所有联系人!" << endl;}}// 查找记录void PhoneBook::Find (const string &fname){if (head_ptr == NULL)// 头为空{cerr << " 还没有任何记录!" << endl;system("pause");}else// 有记录{Person *p = head_ptr;while (p != NULL && !(p -> FindName (fname)))// 遍历{p = p -> next_ptr;}if (p != NULL) // 找到了{cout << fname << " 的电话号码是:" << p -> GetTel() << endl; system("pause");}else // 没找到{cerr << " 未找到这条记录!" << endl;system("pause");}}}// 保存到文件void PhoneBook::Save(){if (head_ptr == NULL)// 头为空{cerr << " 还没有任何记录!" << endl;system("pause");else// 有记录{ofstream ofile("PhoneBook.txt",ios::out|ios::trunc);// 打开文件if (!ofile){cerr << " 无法打开PhoneBook.txt" << endl;system("pause");}else// 成功打开{ofile.seekp(0,ios::beg);// 重定位Person *p = head_ptr;int i=1;ofile << " 电话本:";while (p != NULL)// 遍历{ofile << '\n' << i << '.'<< p -> GetName() << '\n'<< " 电话:" << setw(15) << p -> GetTel();p = p -> next_ptr;i++;}ofile.close();// 关闭文件cout << " 成功保存到文件, 请查看PhoneBook.txt" << endl; }}}// 从文件中读取void PhoneBook::Load(){string filename;cout << " 请输入文件名(XXXXX.XXX):" << endl;cin >> filename;ifstream ifile(filename.c_str(), ios::in);// 打开文件if (!ifile)cerr << " 无法打开" << filename << endl;system("pause");}else// 成功打开{ifile.seekg(0,ios::beg);// 重定位int z;string str;getline(ifile,str);// 欢迎信息while(!ifile.eof()){ifile >> z;// 数字ifile.get();// 点string name;string tel;getline(ifile,name);// 名字ifile >> tel >> tel;// 电话undergraduate per(name,tel);Create (per);}Delete("");ifile.close();cout << " 成功从文件" << filename << " 中读取记录!" << endl; }}// 全部打印void PhoneBook::PrintAll(){if (head_ptr == NULL)// 头为空{cerr << " 还没有任何记录!" << endl;system("pause");}else// 有记录{undergraduate *p = head_ptr;int i=1;while (p != NULL)// 遍历{cout << left << setw (4) << i << setw(20)<< p -> GetName() << setw(15) << p -> GetTel() << endl; p = p -> next_ptr;i++;}system("pause");}}// 析构PhoneBook::~PhoneBook(){undergraduate *temp = head_ptr;while (head_ptr != NULL){head_ptr = head_ptr -> next_ptr;delete temp;temp = head_ptr;}cout << " 已删除所有联系人!" << endl;}// 功能选择int Choice (void){int ch;cout << "\t\t\t 请选择:\n"<< "\t\t\t1. 添加新的联系人\n"<< "\t\t\t2. 删除某个联系人\n"<< "\t\t\t3. 删除所有联系人\n"<< "\t\t\t4. 查询某个联系人\n"<< "\t\t\t5. 查询所有联系人\n"<< "\t\t\t6. 将电话本导出到文件\n"<< "\t\t\t7. 从文件导入电话本\n"<< "\t\t\t0. 退出系统" << endl;cin >> ch;return ch;}main(){cout << "\t\t\t 欢迎您使用电话本系统!\n\n" << endl; PhoneBook mypb;int ch;while (ch=Choice()){switch(ch){case 1:// 新增联系人{string name;string tel;cout << " 请输入联系人姓名:" << endl;cin.get();getline (cin,name);cout << " 请输入联系人电话:" << endl;cin >> tel;undergraduate per(name,tel);mypb.Create(per);break;}case 2:// 删除联系人{string deletename;cout << " 请输入要删除的联系人姓名:"<< endl;cin.get();getline (cin,deletename);mypb.Delete(deletename);break;}case 3:// 删除所有联系人{mypb.DeleteAll();break;}case 4:// 查询某个联系人{string fname;cout << " 请输入要查询的联系人姓名:"cin.get();getline (cin,fname);mypb.Find(fname);break;}case 5:// 查询所有联系人{mypb.PrintAll();break;}case 6:// 将电话本导出到文件{mypb.Save();break;}case 7:// 从文件导入电话本{mypb.Load();break;}default:{cerr << " 输入错误, 请重新输入!" << endl; break;}}}cout << " 感谢您使用电话本系统, 再见!" << endl;system("pause");return 0;}。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

C语言版用链表实现通讯录“标头.h”#include<stdio.h>#include<stdlib.h>#include<string.h>#define Len sizeof(Lnode)int seat;//全局变量,用于存储通讯录成员信息typedef struct Lnode{int number; //学号char name[20];//名字double telenum;//电话struct Lnode *next;//定义一个指向下一个节点的指针} Lnode,*LinkList;//把struct Lnode*重定义为LinkListLinkList creatIncreLink();void deleteElem(LinkList l,int i);int delName(LinkList l,char name[]);int delNum(LinkList l,int n);void insertYouxu(LinkList l,LinkList Elem);void printList(LinkList l);LinkList prior(LinkList l,LinkList p);int searchName(LinkList l,char name[]);int searchNum(LinkList l,int n);#include<stdio.h>#include"标头.h"LinkList creatIncreLink(){LinkList p;int num=1,number;double telenum;char name[20],temp;LinkList L,P;L=(LinkList)malloc(Len); //创建头结点L->next = NULL;printf("请输入学生学号、姓名和电话号码,建立通讯录,以'-1'为输入结果标志\n");printf("请输入学号 %d:");scanf("%d",&number);printf("请输入姓名 %d:");temp=getchar();gets(name);printf("请输入电话号码 %d:");scanf("%lf",&telenum);while (number >= 0){p = (LinkList)malloc(Len); //新分配结点p->number = number;p->telenum = telenum;strcpy(p->name,name);insertYouxu(L,p); //有序地插入新结点num++;printf("请输入学号 %d:",&num);scanf("%d",&number);printf("请输入姓名 %d:",num);temp=getchar();gets(name);printf("请输入电话号码 %d:",num);scanf("%lf",&telenum);}return(L);}void deleteElem(LinkList l,int i) //删除函数{LinkList p=l,q;//让p指向lint j=0;//循环变量jwhile(p->next&&j<i-1) //循环让p指向第i个元素的前驱 {p=p->next;j++;}if(p->next==0) //判断下一个元素是否为空printf("ERROR");q=p->next;//将p指向第i个元素p->next=q->next;//p的next指向q的nextfree(q);//释放q链表}int delName(LinkList l,char name[]){int flag=0;LinkList p=l->next;seat=1;if(l->next==NULL)printf("该链表中没有元素");else{while(p!=NULL){if(strcmp(p->name,name)!=0){flag=1;printf("%s",p->name);p=p->next;deleteElem(l,seat);}else{p=p->next;seat++;}}if(flag==1)printf("被删除");}return flag;}int delNum(LinkList l,int n){int flag=0;LinkList p=l->next;seat=1;if(l->next==NULL)printf("没有元素");else{while(p!=NULL){if(p->number<=n){if(p->number==n){flag=1;printf("%d",p->number);p=p->next;deleteElem(l,seat);}}else{p=p->next;seat++;}}printf("被删除");}return flag;}void insertYouxu(LinkList l,LinkList Elem){LinkList p=l->next;while(p!=NULL&&Elem->number>=p->number) {if(p->number==Elem->number){printf("重复输入\n");return;}p=p->next;}if(p==NULL){p=prior(l,p);Elem->next=NULL;p->next=Elem;}else{p=prior(l,p);Elem->next=p->next;p->next=Elem;}}void printList(LinkList l){LinkList p=l;int n=1;printf("内容");if(l==NULL||l->next==NULL)printf("没有元素\n");elsewhile(p->next!=NULL){printf(" - %-9d",n,p->next->number);printf(" %-5s %.0f\n",p->next->name,p->next->telenum); p=p->next;n++;}}LinkList prior(LinkList l, LinkList p){LinkList p_prior=l;if(l->next==NULL)return(l);while(p_prior->next!=p)p_prior=p_prior->next;return(p_prior);}int searchName(LinkList l,char name[]){int flag=0;LinkList p=l->next;seat=1;if(l->next==NULL||l==NULL)printf("查找失败");else{while(p!=NULL){if(!strcmp(p->name,name)){flag=1;printf("要查找的是%d位通讯录成员\n",seat);printf("学号:%d 名字:%s 电话:%f\n",p->number,p->name,p->telenum); }p->next;seat++;}}return flag;}int searchNum(LinkList l,int n){int flag=0;LinkList p=l->next;seat=1;if(l->next==NULL)printf("查找失败");else{while(p!=NULL){if(p->number<=n)if(p->number==n){flag=1;printf("要查找的是%d个成员\n",seat);printf("学号:%d 姓名:%s 电话:%f",p->number,p->telenum,p->telenum); }p=p->next;seat++;}}return flag;}int main(void){LinkList l=NULL,p;int flag=0;int menu;char temp;system("color 3f");printf("输入1通讯录的建立\n");printf("输入2插入通讯录\n");printf("输入3查询通讯录\n");printf("输入4删除通讯录\n");printf("输入5显示通讯录信息\n");printf("输入0退出\n");scanf("%d",&menu);while(menu!=0){switch(menu){case 1:l=creatIncreLink();printf("建立通讯录\n");printList(l);flag=1;break;case 2:if(flag==1){int number;double telenum;char name[20];char temp;printf("请输入学号\n");scanf("%d",&number);printf("请输入姓名\n");scanf("%s",&name[20]);printf("请输入电话号码");scanf("%f",&telenum);p=(LinkList)malloc(Len);p->number=number;strcpy(p->name,name);p->telenum=telenum;insertYouxu(l,p);printf("插入后\n");printList(l);}else{printf("error\n");}break;case 3:int way,n,s;char na[20],temp;if(l!=NULL){if(flag){printf("选择查找方式1,按学号查找2按姓名"); scanf("%d",&way);if(way==1){printf("请输入学号\n");scanf("%d",&n);s=searchNum(l,n);if(s==0)printf("shibai");}else if(way==2){printf("请输入姓名");temp=getchar();gets (na);s=searchName(l,na);if(s==2)printf("失败");}else printf("无记录");}break;}else printf("无记录");break;case 4:printf("1,按序号删除2 按学号,3按姓名\n"); scanf("%d",&way);if(way==1){int n;printf("请输入序号");scanf("%d",&n);printf("删除后\n");deleteElem(l,n);printList(l);}else if(way==2){int n,f;printf("请输入学号");scanf("%d",&n);f=delNum(l,n);if(f!=0){printf("删除后");printList(l);}else printf("失败");}else if(way==3){char na[20],temp;int f;printf("输入姓名");temp=getchar();gets(na);f=delName(l,na);if(f!=0){printf("删除后");printList(l);}else printf("失败");}else printf("error\n");break;case 5:printf("内容如下\n");printList(l);break;case 0:exit(0);default:printf("重新输入"); }printf("选择\n");scanf("%d",&menu);}}。

相关文档
最新文档