李刚是一爱折腾的人,当然爱折腾的人均有梦想,他想当中国的盖次呢。可不,现在个人好友信息多了,复杂了,他想制作一个个人通讯录的制作管理软件。 刚好这个学期学了数据结构课,所以他准备使用数据结构知识来实现了。并考虑使用双向链表作数据结构。并制定了初步要求:
(1)每个好友信息包含姓名、性别、住址、邮编、几岁、电话、QQ、微信帐号、生日等。
(2)作为一个完整的系统,应具有友好的界面和较强的容错能力。
#include<iostream>
#include<string>
#include<fstream>
using namespace std;
struct tongxunlu //数据类
{
char name[10]; //姓名
char home[100]; //家庭住址
char phonenumber[20]; //手机电话号码
char email[20]; //电子邮箱
char qq[20]; //QQ
int s;
tongxunlu * next;
void ReadFile(istream & in); //文件开闭
void input();
void print();
};
int x=0;
int j=1;
char a;
void tongxunlu::ReadFile(istream & in) //从文件把数据读入到程序
{
in>>name>>home>>phonenumber>>email>>qq;
}
void tongxunlu::input() //信息输入
{
cout<<"请输入姓名"<<endl;
cin>>name;
cout<<"请输入家庭住址"<<endl;
cin>>home;
cout<<"请输入手机号码"<<endl;
cin>>phonenumber;
cout<<"请输入电子邮箱"<<endl;
cin>>email;
cout<<"请输入QQ号"<<endl;
cin>>qq;
s=j++;
}
void tongxunlu::print() //信息输出
{
cout<<"姓名:"<<name<<endl;
cout<<"家庭住址:"<<home<<endl;
cout<<"手机号码:"<<phonenumber<<endl;
cout<<"电子邮箱:"<<email<<endl;
cout<<"QQ:"<<qq<<endl;
cout<<endl;
}
class Message //功能类
{
public:
Message(); //构造数据结构
~Message(); //释放链表
void Save(); //数据保存到文件
tongxunlu * Search_name(char *); //用名字查找
tongxunlu * Search_home(char *); //用家庭住址查找
tongxunlu * Search_phonenumber(char *); //用手机号码查找
void Show(); //显示
void Insert(); //插入
void Remove(); //删除指针
void Change(); //更改
private:
tongxunlu * front,* rear,*prior;
ifstream in; //定义读,写文件对象
ofstream out;
};
Message::Message()
{
front=new tongxunlu; //初始化
front->next=new tongxunlu;
rear=front->next;
in.open("tongxunlu.txt"); //打开外存文件,看是否有数据存在
if(!in) 打不开
cout<<"电话系统中没有任何号码,请输入号码"<<endl;
else
{
while(!in.eof()) //将数据读取到程序,eof()表示文件结束
{
rear->ReadFile(in);
if(rear->name[0]=='\0')break; 没有数据就跳出
rear->next=new tongxunlu; 有数据就插在链表后面
rear=rear->next;
}
in.close();
cout<<"读取电话号码系统成功"<<endl;
}
cout<<"输入任意字母继续"<<endl;
cin>>a;
}
Message::~Message() //释放链表
{
tongxunlu * temp;
while(front->next!=rear)
{
temp=front;
front=front->next;
delete temp;
}
delete front,rear; //删除头尾指针
}
void Message::Save() //保存文件
{
out.open("tongxunlu.txt"); //建立外存文件Teletongxunlu.txt
for(tongxunlu *p=front->next;p!=rear;p=p->next) 从头走到尾
out<<p->name<<"\t"<<p->home<<"\t"<<p->phonenumber<<"\t"<<p->email<<p->qq<<endl; //将数据存到外存文件
out.close();
cout<<"保存成功!"<<endl;
}
void Message::Insert() //插入
{
rear->input(); //从链表尾部插入
rear->next=new tongxunlu;
rear=rear->next;
cout<<endl<<"插入成功"<<endl;
}
tongxunlu * Message::Search_name(char * name) //用名字查找
{
for(tongxunlu *p=front->next;p!=rear;p=p->next)
if(p!=NULL&&!strcmp(p->name,name))
{
if(x==4)
{
p->print();
return p;
}
else
return p;
}
if(x==4)
cout<<"查无此人"<<endl;
return 0;
}
tongxunlu * Message::Search_home(char * home) //用家庭住址查找
{
for(tongxunlu *p=front->next;p!=rear;p=p->next)
if(p!=NULL&&!strcmp(p->home,home))
{
if(x==3)
{
p->print();
return p;
}
else
return p;
}
if(x==3)
cout<<"查无此人"<<endl;
return 0;
}
tongxunlu * Message::Search_phonenumber(char * phonenumber) //用手机号码查找
{
for(tongxunlu *p=front->next;p!=rear;p=p->next)
if(p!=NULL&&!strcmp(p->phonenumber,phonenumber))
{
if(x==5)
{
p->print();
return p;
}
else
return p;
}
if(x==5)
cout<<"查无此人"<<endl;
return 0;
}
void Message::Change() //修改信息
{
char name[30];
cout<<"请输入要修改的人的姓名:";
cin>>name;
if(Search_name(name))
{
cout<<"\t\t已找到个人的信息,请输入新的信息!"<<endl;
Search_name(name)->input();
cout<<"修改成功!"<<endl;
}
else
{
cout<<"\t\t查无此人!"<<endl;
}
}
void Message::Remove() //删除
{
char name[30];
tongxunlu * p=new tongxunlu,*temp=NULL;
cout<<"请输入要删除人的姓名:"<<endl;
cin>>name;
p->next=Search_name(name); //先进行查找,找到所要删除的结点
if(Search_name(name))
{
temp=p->next;
p->next=temp->next;
delete temp;
cout<<"\t\t删除成功!"<<endl;
}
else
{
cout<<"\t\t查无此人!"<<endl;
}
}
void Message::Show()
{
for(tongxunlu * p=front->next;p!=rear;p=p->next)
p->print();
}
int main()
{
bool flag=true;
Message tele;
char name[30];
char home[30];
char phonenumber[30];
while(flag)
{
system("cls");
cout<<" 通讯录 "<<endl;
cout<<" 1.增加电话号码 "<<endl;
cout<<" 2.显示电话号码 "<<endl;
cout<<" 3.用家庭住址查找 "<<endl;
cout<<" 4.用姓名查找 "<<endl;
cout<<" 5.用手机号码查找 "<<endl;
cout<<" 6.修改个人信息 "<<endl;
cout<<" 7.删除个人信息 "<<endl;
cout<<" 8.保存个人信息 "<<endl;
cout<<" 0.退出系统 "<<endl;
cout<<"\n\t\t\n\t\t请选择:";
cin>>x;
switch(x)
{
case 0:flag=false;break;
case 1:tele.Insert();break;
case 2:tele.Show();break;
case 3:
cout<<"请输入查找的家庭住址"<<endl;
cin>>home;
tele.Search_home(home);break;
case 4:
cout<<"请输入查找的姓名"<<endl;
cin>>name;
tele.Search_name(name);break;
case 5:
cout<<"请输入查找的手机号码"<<endl;
cin>>phonenumber;
tele.Search_phonenumber(phonenumber);break;
case 6:tele.Change();break;
case 7:tele.Remove();break;
case 8:tele.Save();break;
}
cout<<"输入任意字母返回"<<endl;
cin>>a;
}
return 0;
}