这也要求貌似太多了
我这刚做了个简单的一点的通讯录
希望对LZ又点帮助
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<conio.h>
typedef struct//表示数据类型,可类比int
{
char name[15];
char city[15];
char telenub[15];//固定电话号码
char email[20];
char qq[13];
char youbian[10];//表示邮编
}DataType;
FILE *fp;
typedef struct node{//结类型定义
DataType data;//节点数据域
struct node * next;//节点指针域
}ListNode;
typedef ListNode * LinkList;
LinkList head;
ListNode *p;
//函数说明
void myprint();
LinkList CreateList();
void InsertNode(LinkList head,ListNode *p);
ListNode * ListFind(LinkList head);
void DelNode(LinkList head);
void PrintList(LinkList head);
//用尾插法建立通讯录链表函数
LinkList CreateList()
{
LinkList head=(ListNode *)malloc(sizeof(ListNode));//申请头结点 分配存储空间
ListNode *p,*rear;
int flag=0;//结束标志置0
rear=head;//尾指针初始指向头结点
if((fp=fopen("record.txt","w+"))==NULL) //打开文件,并判断打开是否正常
{
printf("打开文件失败!!\n");//没打开
exit(0); //退出
}
fprintf(fp,"%-15s%-20s%-15s%-20s%-10s%-12s\n","姓名","城市","电话","邮箱","QQ","邮编" );
while(flag==0)
{
p=(ListNode *)malloc(sizeof(ListNode));//申请新结点
printf(" 姓名 地址(城市) 电话 邮箱 QQ 邮编 \n");
scanf("%s%s%s%s%s%s",p->data.name ,p->data.city ,p->data.telenub ,p->data.email,p->data.qq,p->data.youbian );
fprintf(fp,"%-15s%-20s%-15s%-20s%-10s%-12s\n",p->data.name ,p->data.city ,p->data.telenub ,p->data.email,p->data.qq,p->data.youbian );
// fclose(fp);
rear->next=p;//新结点连接到尾结点之后
rear=p;//尾指针指向新结点
printf("是否结束建表?(1/0):");
scanf("%d",&flag);//读入一个标志数据
}
rear->next=NULL;//终端结点指针域置空
return head;//返回链表头指针
}
//在通讯录链表head中插入节点
void InsertNode(LinkList head,ListNode *p)
{
ListNode *p1,*p2;
p1=head;
p2=p1->next;
while(p2!=NULL&&strcmp(p2->data.name,p->data.name)<0)
{
p1=p2;//p1指向刚访问过的结点
p2=p2->next;//p2指向表的下一个结点
}
p1->next=p;//插入p所指向的的结点
p->next=p2;//连接表中剩余部分
}
//有序通讯录链上的查找
ListNode *ListFind(LinkList head)
{
ListNode *p;
char telenub[13];
char name[15];
int temp;
printf("请选择按姓名或电话查询(1/2):\n");
p=head->next;//假定通讯录表带头结点
scanf("%d",&temp);
if(temp==1)
{
printf("请输入要查找者的姓名");
scanf("%s",name);
while(p&&strcmp(p->data.name,name)!=0)
p=p->next;
if(p==NULL||strcmp(p->data.name,name)>0)
p=NULL;//没有查到要查找的姓名
}
else
if(temp==2){
printf("请输入要查找的电话号码:\n");
scanf("%s",telenub);
while(p&&strcmp(p->data.telenub,telenub)<0)
p=p->next;
if(p==NULL||strcmp(p->data.telenub,telenub)>0)
p=NULL;
}
return p;
}
//通讯录链表上结点的删除
//先调用查询函数,查询到要删除的结点,删除结点即可。
void DelNode(LinkList head)
{
char temp;
ListNode *p,*q;
p=ListFind(head);//调用查找函数
if(p==NULL)
{
printf("没有查到要删除的通讯者!\n");
return;
}
printf("真的要删除改结点吗?(y/n):\n");
scanf("%s",&temp);
if(temp=='y'||temp=='Y')
{
q=head;
while(q!=NULL && q->next!=p)//此循环的含义是将q的指针域赋给p
q=q->next;
q->next=p->next;//删除结点 这里为什么不能用p=p->next
free(p);//释放被删除的节点空间
printf("通讯者已被删除!\n");
}
}
//通讯录链表的输出函数
void PrintList(LinkList head)
{
ListNode *p;
p=head->next;//因为链表带头结点,使p指向链表开始结点
printf(" 姓名 地址 电话 邮 箱 QQ 邮编 \n");
printf("-------------------------------------------------------------------------\n");
/*if((fp=fopen("d://record.txt","r+"))==NULL) //打开文件,并判断打开是否正常
{
printf("打开文件失败!!\n");//没打开
exit(0); //退出
}
while(feof(fp)==0)
{
fscanf(fp,"%15s%20s%15s%30s%10s%10s",p->data.telenub, p->data.name ,p->data.city ,p->data.email,p->data.qq,p->data.youbian);
printf("%15s,%20s,%15s,%30s,%10s,%10s",p->data.telenub, p->data.name ,p->data.city ,p->data.email,p->data.qq,p->data.youbian);
}
fclose(fp);*/
while(p!=NULL)
{
printf("%10s%10s%13s%15s%13s%12s\n",p->data.name,p->data.city,p->data.telenub,p->data.email,p->data.qq,p->data.youbian);
printf("-------------------------------------------------------------------------\n");
p=p->next;//后移一个结点
}
}
void myprint() /* 显示菜单界面 */
{
printf("\n\n");
printf(" |--------------------------------|\n");
printf(" |★☆欢迎进入通讯录管路系统☆★ |\n");
printf(" |--------------------------------|\n");
printf(" | 请输入选项编号(0-5): |\n");
printf(" |--------------------------------|\n");
printf(" | 1--创建通讯录链表 |\n");
printf(" | 2--好友结点的添加 |\n");
printf(" | 3--好友结点的查询 |\n");
printf(" | 4--好友结点的删除 |——————\n");
printf(" | 5--输出通讯录链表 |08信工一班 |\n");
printf(" | 0--退出 | 谭鹏 |\n");
printf(" |--------------------------------|——————\n");
printf("\n\n\n");
}
void main()
{
char choose,yes_no;
do
{
myprint(); /* 显示主菜单 */
printf("\t");
choose=getch();
switch(choose)
{
case '1':printf("********************************************************************\n");
printf("\t\t* 通 讯 录 链 表 的 建 立 *\n ");
printf("\t********************************************************************\n");
head=CreateList(); break; /* 创建 */
case '2':
printf("****************************************************************\n");
printf("\t\t* 通 讯 录 链 表 的 添 加 *\n ");
printf("\t ****************************************************************\n");
printf("\t姓名 地址 电话 邮 箱 QQ 邮编 \n");
printf("\t*******************************************************************\n");
p=(ListNode *)malloc(sizeof(ListNode));//申请新结点
scanf("%s%s%s%s%s%s",p->data.name ,p->data.city ,p->data.telenub ,p->data.email,p->data.qq,p->data.youbian );
if((fp=fopen("tianjia.txt","w+"))==NULL) //打开文件,并判断打开是否正常
{
printf("打开文件失败!!\n");//没打开
exit(0); //退出
}
fprintf(fp,"%-15s%-20s%-15s%-20s%-10s%-12s\n","姓名","城市","电话","邮箱","QQ","邮编" );
InsertNode(head,p);
fprintf(fp,"%-15s%-20s%-15s%-20s%-10s%-12s\n",p->data.name ,p->data.city ,p->data.telenub ,p->data.email,p->data.qq,p->data.youbian );
fclose(fp);
printf("\t\t\t结点添加完毕!");
break; /* 添加 */
case '3':
printf("************************************************************\n");
printf("\t* 好 友 信 息 的 查 询 *\n ");
p=ListFind(head);
if(p!=NULL){
printf(" 姓名 地址 电话 邮 箱 QQ 邮编 \n");
printf("*************************************************************************\n");
printf("%10s%10s%13s%15s%13s%10s\n",p->data.name,p->data.city,p->data.telenub,p->data.email,p->data.qq,p->data.youbian);
printf("*************************************************************************\n");
}
else
printf("没有查到要查询的好友!");
break; /* 查询 */
case '4':
printf("************************************************************\n");
printf("* 好 友 信 息 的 删 除 *\n ");
printf("************************************************************\n");
DelNode(head);//删除结点
break; /* 删除 */
case '5':
printf("************************************************************\n");
printf("\t\t* 显 示 所 有 好 友 信 息 *\n ");
printf("\t ************************************************************\n");
PrintList(head); break; /* 显示 */
case '0': break;
default:printf("\n %c为非法选项!\n",choose);
}
if(choose=='0')
break;
printf("\n 按Y键回主目录:\n\n\n");
do
{
yes_no=getch();
}while(yes_no!='Y'&&yes_no!='y');
}while(yes_no!='Y'||yes_no!='y');
}
温馨提示:答案为网友推荐,仅供参考