课程设计2号

李刚是一爱折腾的人,当然爱折腾的人均有梦想,他想当中国的盖次呢。可不,现在个人好友信息多了,复杂了,他想制作一个个人通讯录的制作管理软件。 刚好这个学期学了数据结构课,所以他准备使用数据结构知识来实现了。并考虑使用双向链表作数据结构。并制定了初步要求:

1每个好友信息包含姓名、性别、住址、邮编、几岁、电话、QQ、微信帐号、生日等。

2作为一个完整的系统,应具有友好的界面和较强的容错能力。

#include
#include
#include
using namespace std;
int x=0;
int j=1;
char a;
struct Number                                  //数据类
{
char name[30];                                //姓名
char sex[30];                                //性别
char home[30];                              //住址 
char age[30];                               //年龄
char phoneNumber[30];                      //手机电话号码
char email[30];                           //电子邮箱
char qq[30];                             //QQ
char weixin[30];                        //微信
char birthday[30];                     //生日
int s;  
Number * next; 
void ReadFile(istream & in);     //文件开闭
void input();
void print();
};
 
void Number::ReadFile(istream & in)          //从文件把数据读入到程序
{
in>>name>>home>>phoneNumber>>email>>qq;
}
 
void Number::input()                           //信息输入
{ 
cout<<"请输入姓名"<>name;
cout<<"请输入性别"<>sex;
cout<<"请输入家庭住址"<>home;
cout<<"请输入年龄"<>age;
cout<<"请输入手机号码"<>phoneNumber;
cout<<"请输入电子邮箱"<>email;
cout<<"请输入QQ号"<>qq;
cout<<"请输入微信号"<>weixin;
cout<<"请输入生日日期"<>birthday;
s=j++;
}
 
void Number::print()                        //信息输出
{
cout<<"姓名:"<next=new Number;
rear=front->next;
in.open("Number.txt");                        //打开外存文件,看是否有数据存在
if(!in)                                       ////打不开
cout<<"电话系统中没有任何号码,请输入号码"<ReadFile(in);                     
if(rear->name[0]=='\0')break;           ////没有数据就跳出
rear->next=new Number;                   ////有数据就插在链表后面
rear=rear->next;
}
in.close();
cout<<"读取电话号码系统成功"<>a;
 }
 
Message::~Message()                       //释放单链表
{
Number * temp;
while(front->next!=rear)
{
temp=front;
front=front->next;
delete temp;
}
delete front,rear;                                 //删除头尾指针
}
 
void Message::Save()                          //保存文件
{
out.open("Number.txt");                    //建立外存文件TeleNumber.txt
for(Number *p=front->next;p!=rear;p=p->next)    ////从头走到尾
out<name<<"\t"<home<<"\t"<phoneNumber<<"\t"<email<qq<input();                                 //从单链表尾部插入
rear->next=new Number;
rear=rear->next;
cout<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<<"查无此人"<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<<"查无此人"<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<<"查无此人"<>name;
if(Search_name(name))
{
cout<<"\t\t已找到个人的信息,请输入新的信息!"<input();
cout<<"修改成功!"<>name;
p->next=Search_name(name);                       //先进行查找,找到所要删除的结点
if(Search_name(name))
{
 
temp=p->next;
p->next=temp->next;                              //摘链 p->next->next
delete temp;

cout<<"\t\t删除成功!"<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<<"                          个人电话号码查询系统                    "<>x;
switch(x)
{
case 0:flag=false;break;
case 1:tele.Insert();break;
case 2:tele.Show();break;
case 3:
cout<<"请输入查找的家庭住址"<>home;
tele.Search_home(home);break;
case 4:
cout<<"请输入查找的姓名"<>name;
tele.Search_name(name);break;
case 5:
cout<<"请输入查找的手机号码"<>phoneNumber;
tele.Search_phoneNumber(phoneNumber);break;
case 6:tele.Change();break;
case 7:tele.Remove();break;
case 8:tele.Save();break;
}
cout<<"输入任意字母返回"<>a;
}
return 0;
}


你可能感兴趣的:(课程设计2号)