/*
*Copyright (c) 2017, 烟台大学计算机学院
*All rights reserved.
*文件名称:wbc.cpp
*作 者:王百琛
*完成日期:2017年12月22日
*版 本 号:v1.0
*
*问题描述:通讯录系统
*输入描述:好多好多的信息
*程序输出:好多好多的操作
*/
#include "txl3.0.h"
#include <stdio.h>
#include <malloc.h> //得到指向大小为Size的内存区域的首字节的指针
#include <string.h>
#include <stdlib.h> //标准库函数
#define NULL 0
#define LEN sizeof(struct book_list) //计算字节
int main()
{
struct book_list *head=NULL;
char num[10];
Welcome();
while(1)
{
printf("******************************\n");
printf("*** 1 添加新的通讯录 ****\n");
printf("*** 2 按名字排序 ****\n");
printf("*** 3 综合操作 ****\n");
printf("*** 4 删除联系人 ****\n");
printf("*** 5 退出系统 ****\n");
printf("******************************\n");
printf("请输入您选择的操作:");
gets(num);
switch(*num)
{
case '1':
{
system("cls");
if(head==NULL)
{
head=Creat(); //创建
print(head);
}
else
{
system("cls");
head=Shifang(head);
head=Creat(); //重新创建
print(head);
}
}
break;
case '2':
{
system("cls");
head=Paixu(head); //排序
}
break;
case '3':
{
system("cls");
head=Contrl(head); //综合操作
}
break;
case '4':
{
system("cls");
head=Delete_txl(head); //删除
print(head);
}
break;
case '5':
system("cls");
head=Shifang(head);
break;
default:
system("cls");
printf("操作错误,此项不存在!\n");
break;
}
if(strcmp(num,"5")==0)
break;
}
return 0;
}
以上为主函数
#include "txl3.0.h"
int n;
//创建函数,不带头结点的链表
struct book_list *Creat(void)//创建booklist类型的函数
{
struct book_list *head,*p1,*p2;//定义上头结点,p1,p2
char name[20];
n=0;
p1=(struct book_list *)malloc(LEN);//给p1开辟内存空间
p2=p1; //强制内存转换并且赋值
printf("请输入通讯录的内容!\n姓名输入为0时表示创建完毕!\n");
printf("请输入姓名:");
gets(name);//输入姓名
if(strcmp(name,"0")!=0)//因为设置的0是退出编辑的方式所以看看是不是不等于零
{
strcpy(p1->name,name);//把名字变量赋值
printf("请输入职业:"); gets(p1->work);
printf("请输入手机:"); gets(p1->Tel);
printf("请输入电子邮件:"); gets(p1->email);
printf("请输入通讯地址:"); gets(p1->address);
head=NULL;
while(1)
{
n=n+1; //记录通讯录人数个数
if(n==1)//如果这个时候只有这一个
head=p1;//则把p1的值附在头结点上
else
p2->next=p1;//p2的next节点上的值被p1覆盖,所以新的值附在p1之前
p2=p1;
printf("请输入姓名:");
gets(name);
if(strcmp(name,"0")==0)
{
break;
}
else
{
p1=(struct book_list *)malloc(LEN);
strcpy(p1->name,name);
printf("请输入职业:"); gets(p1->work);
printf("请输入手机:"); gets(p1->Tel);
printf("请输入电子邮件:"); gets(p1->email);
printf("请输入通讯地址:"); gets(p1->address);
}
}
p2->next=NULL;
return head;
}
else
return 0;
}
//功能描述:输出函数
void print(struct book_list *head)
{
struct book_list *p;
if(head!=NULL)//看看他存不存在
{
p=head;
printf("本通讯录现在共有%d人:\n",n);
printf("---姓名-------职业--------手机-------Email-------通讯地址\n");
printf("==================================\n");
do
{
printf("== %s",p->name); printf(" ");
printf("%s",p->work); printf(" ");
printf("%s",p->Tel); printf(" ");
printf("%s",p->email); printf(" ");
printf("%s",p->address); printf(" \n");
p=p->next;
}while(p!=NULL);
printf("==================================\n");
}
else
printf("通讯录为空,无法输出!\n");
}
//新增联系人
struct book_list *insert(struct book_list *head)
{
struct book_list *p0,*p1,*p2;
char name[20];
p1=head;
printf("请输入增加的内容:\n");
printf("请输入姓名:"); gets(name);
if(strcmp(name,"0")==0)
{
printf("姓名不能为0,增加失败!\n");
return(head);
}
else
{
p0=(struct book_list *)malloc(LEN);
strcpy(p0->name,name);
printf("请输入职业:"); gets(p0->work);
printf("请输入手机:"); gets(p0->Tel);
printf("请输入电子邮件:"); gets(p0->email);
printf("请输入通讯地址:"); gets(p0->address);
n=n+1;
if(head==NULL)
{
head=p0;
p0->next=NULL;
return head;
}
else
{
while(strcmp(p0->name,p1->name)>0&&(p1->next!=NULL))//输入的不一样,并且
{
p2=p1;
p1=p1->next;
}
if(strcmp(p0->name,p1->name)<0 || strcmp(p0->name,p1->name)==0)//zuoleyigepaixu
{
if(head==p1)
{
head=p0;
}
else
{
p2->next=p0;
}
p0->next=p1;
}
else
{
p1->next=p0;
p0->next=NULL;
}
return head;
}
}
}
//功能描述:删除姓名
struct book_list* Delete_txl(struct book_list *head)
{
struct book_list *p,*q;
char name[30];
if(head==NULL)
{
printf("通讯录为空,无法显示!\n");
return head;
}
p=head;
printf("请输入需要删除的人的姓名:");
gets(name);
if(strcmp(head->name,name)==0)//如果核对上了
{
head=head->next;
free(p);//利用free函数进行destory
printf("删除操作成功!\n");
n--;
return head;
}
else
{
q=head,p=head->next;
while(p!=NULL)
{
if(strcmp(p->name,name)==0)
{
q->next=p->next;
free(p);
printf("删除操作成功!\n");
n--;
return head;
}
p=p->next;
q=q->next;
}
}
}
//显示函数
struct book_list *Display(struct book_list *head)
{
struct book_list *p1,*p2;
char name[30];
int m;
if(head==NULL)
{
printf("通讯录为空,无法显示!\n");
return head;
}
p1=head;
m=0;
printf("请输入需要显示人的姓名:");
gets(name);
while(p1!=NULL)
{
while((strcmp(p1->name,name))!=0 && p1->next!=NULL)//把名字校对
{
p2=p1;
p1=p1->next;
}
if(strcmp(p1->name,name)==0)
{
m++;
printf("%s的通讯内容如下:\n",name);
printf("---姓名--------职业--------手机-------Email------通讯地址\n");
printf("==================================\n");
printf("== %s",p1->name);printf(" ");
printf("%s",p1->work);printf(" ");
printf("%s",p1->Tel);printf(" ");
printf("%s",p1->email);printf(" ");
printf("%s",p1->address); printf(" \n");
printf("==================================\n");
}
p1=p1->next;
}
if(m==0)
{
printf("此人未在本通讯录中!\n");
}
return(head);
}
//排序函数
struct book_list *Paixu(struct book_list *head)
{
struct book_list *p1,*p2;
int i,j;
struct book_list1
{
char name[30];
char work[30];
char Tel[30];
char email[30];
char address[30];
};
struct book_list1 px[200];
struct book_list1 temp;
if(head==NULL)
{
printf("通讯录为空,无法排序!\n");
return(head);
}
p1=head;
for(i=0;i<n,p1!=NULL;i++)
{
strcpy(px[i].name,p1->name);
strcpy(px[i].work,p1->work);
strcpy(px[i].Tel,p1->Tel);
strcpy(px[i].email,p1->email);
strcpy(px[i].address,p1->address);
p2=p1;
p1=p1->next;
}
head=Shifang(head);
for(j=0;j<n-1;j++)
{
for(i=j+1;i<n;i++)
{
if(strcmp(px[i].name,px[j].name)<0)//
{
temp=px[i];
px[i]=px[j];
px[j]=temp;
}
}
}
p1=(struct book_list *)malloc(LEN);
p2=p1;
strcpy(p1->name,px[0].name);
strcpy(p1->work,px[0].work);
strcpy(p1->Tel,px[0].Tel);
strcpy(p1->email,px[0].email);
strcpy(p1->address,px[0].address);
head=p1;
for(i=1;i<n;i++)
{
p1=(struct book_list *)malloc(LEN);
strcpy(p1->name,px[i].name);
strcpy(p1->work,px[i].work);
strcpy(p1->Tel,px[i].Tel);
strcpy(p1->email,px[i].email);
strcpy(p1->address,px[i].address);
p2->next=p1;
p2=p1;
}
p2->next=NULL;
printf("按姓名排序后为:\n");
print(head);
return(head);
}
//姓名查找函数
struct book_list *search(struct book_list *head)
{
struct book_list *p1,*p2;
int m;
char name[30];
if(head==NULL)
{
printf("通讯录为空,无法分类查找!\n");
return(head);
}
p1=head;
printf("****************************\n");
printf("** 请输入需要查找的姓名 **\n");
printf("****************************\n");
m=0;
gets(name);
while(p1!=NULL)
{
while(strcmp(p1->name,name)!=0&&p1->next!=NULL)
{
p2=p1;
p1=p1->next;
}
if(strcmp(p1->name,name)==0)
{
m++;
printf("你查找的内容是:\n");
printf("+++++++++++++++++++++++++++++++++++\n");
printf("++ %s %s %s %s %s\n",p1->name,p1->work,p1->Tel,p1->email,p1->address);
printf("+++++++++++++++++++++++++++++++++++\n");
}
p1=p1->next;
if(m==0)
{
printf("此人未在本通讯录中!\n");
}
break;
}
return(head);
}
//释放内存函数
struct book_list *Shifang(struct book_list *head)
{
struct book_list *p1;
while(head!=NULL)
{
p1=head;
head=head->next;
free(p1);
}
return(head);
}
//综合操作函数
struct book_list *Contrl(struct book_list *head)
{
char num[10];
while(1)
{
printf("************************\n");
printf("*** 1 姓名查找 ****\n");
printf("*** 2 单个显示 ****\n");
printf("*** 3 增加联系人 ****\n");
printf("*** 4 修改联系人 ****\n");
printf("************************\n");
printf("请输入您选择的操作:");
gets(num);
switch(*num)
{
case '1':
{
head=search(head); //姓名查找
print(head);
}
break;
case '2':
{
head=Display(head); //显示
}
break;
case '3':
{
head=insert(head); //增加
print(head);
}
break;
case '4':
{
head=Modify(head);
}
case '5':
return head;
default:
printf("操作错误,此项不存在!\n");
break;
}
if(strcmp(num,"6")==0)
break;
}
return head;
}
void Welcome()/*欢迎界面*/
{
printf("\n\n");
printf(" \t┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n");
printf(" \t┃**********************************************************┃\n");
printf(" \t┃***┏━━━━━━━━━━━━━━━━━━━━━━━━┓***┃\n");
printf(" \t┃***┃************************************************┃***┃\n");
printf(" \t┃***┃*** ****┃***┃\n");
printf(" \t┃***┃*** 欢迎进入我的通信录管理系统 ****┃***┃\n");
printf(" \t┃***┃*** ****┃***┃\n");
printf(" \t┃***┃*** ****┃***┃\n");
printf(" \t┃***┃*** 制作人:王百琛 ****┃***┃\n");
printf(" \t┃***┃*** ****┃***┃\n");
printf(" \t┃***┃*** 2017.12.21 ****┃***┃\n");
printf(" \t┃***┃*** ****┃***┃\n");
printf(" \t┃***┃************************************************┃***┃\n");
printf(" \t┃***┗━━━━━━━━━━━━━━━━━━━━━━━━┛***┃\n");
printf(" \t┃**********************************************************┃\n");
printf(" \t┗━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛\n");
}
struct book_list*Modify(struct book_list *head)
{
char ch;
struct book_list *p1,*p2;
char name[30];
int qe;char c;
if(head==NULL)
{
printf("通讯录是空的\n");
return head;
}
p1=head;
qe=0;
printf("请输入要改变的人的姓名\n");
gets(name);
while(p1!=NULL)
{
if((strcmp(p1->name,name))!=0 && p1->next!=NULL)
{
system("cls");
printf("所要修改的学生信息如下\n");
printf("%s的通讯内容如下:\n",name);
printf("---姓名--------职业--------手机-------Email------通讯地址\n");
printf("==================================\n");
printf("== %s",p1->name);printf(" ");
printf("%s",p1->work);printf(" ");
printf("%s",p1->Tel);printf(" ");
printf("%s",p1->email);printf(" ");
printf("%s",p1->address); printf(" \n");
printf("==================================\n");
do
{
printf("1.修改姓名 2.修改职业 3.修改手机 4.修改邮箱 5.修改地址");
scanf("%s",c);
if(c!='5')
printf("请输入新的信息: ");
switch(c)
{
case '1': scanf("== %s",p1->name);
case '2': scanf("%s",p1->work);
case '3': scanf("%s",p1->Tel);
case '4': scanf("%s",p1->email);
case '5': scanf("%s",p1->address);
printf("==================================\n");
default: return (head); break;
}
printf("\n\t ***修改成功***\n");
}while(c!='6');
}
}
/* else if(//未找到联系人
{
printf("\n未找到联系人!\n");
printf("\n是否继续修改(Y/N)?\n");
scanf("%s",ch);
if(ch=='Y'||ch=='y')
{
printf("请输入要改变的人的姓名\n");
gets(name);
Modify(head);
}
else if
{return;}
}*/
}
以上为函数算法库
#ifndef TXL3_0_H_INCLUDED
#define TXL3_0_H_INCLUDED
#include <stdio.h>
#include <malloc.h> //得到指向大小为Size的内存区域的首字节的指针
#include <string.h>
#include <stdlib.h> //标准库函数
#include<cstdio>
#include<fstream>
#define NULL 0
#define LEN sizeof(struct book_list) //计算字节
struct book_list //定义了一个booklist的结构体
{
char name[30]; //名字
char work[30]; //职业
char Tel[30]; //手机
char email[30]; //电子邮件
char address[30]; //通讯地址
struct book_list *next; //指针
};
struct book_list *Shifang(struct book_list *head); // 释放内存的函数
struct book_list *Creat(void);//创建链表
void print(struct book_list *head);//将链表信息打印
struct book_list *insert(struct book_list *head);//插入节点。。。。。也就是增加联系人
struct book_list *Delete_txl(struct book_list *head);//删除通讯录中的某个人
struct book_list *Display(struct book_list *head);//单独的显示某个对应节点的人
struct book_list *Paixu(struct book_list *head);//将已经新增的进行排序
struct book_list *search(struct book_list *head);//
struct book_list *Shifang(struct book_list *head);//释放内存空间
struct book_list *Contrl(struct book_list *head);//
struct book_list*Modify(struct book_list *head);//xiugai
void Welcome();
#endif // TXL3_0_H_INCLUDED
以上为头文件内容