C++使用链表存储实现通讯录功能管理

本文实例为大家分享了C++使用链表存储实现通讯录功能管理的具体代码,供大家参考,具体内容如下

简介

这是第二周老师给的一个小项目要求实现基本通讯录功能,有数据的增删改查,包含插入时间的能力。

代码详情

头文件

#include <iostream>
#include <string>
#include<malloc.h> //system功能调用 
#include <windows.h> //使用本地系统API获取插入时间 
#include <sstream>

基本存储结构体

typedef struct info{
    string number;
    string date;
    string name;
    string adress;
    string birthday; 
}A;
typedef struct LNode{
    A data; 
    struct LNode *next;
}LNode,*LinkList;

链表数据初始化
用前插法插入数据

int InitList(LinkList &L){ //初始化链表 
    L = new LNode;
    L->next = NULL;
    return OK;
}
int ListInsert(LinkList &L,string name,string adress,string birthday,string date,string number){ //考虑使用数组来赋值 
    LinkList p; p= new LNode;
    p->data.name = name;
    p->data.adress = adress;
    p->data.date = date;
    p->data.birthday = birthday;
    p->data.number = number;
    p->next = L->next;
    L->next = p;
    return OK;
} 

本地WindowsAPI调用插入时间

SYSTEMTIME sys; 
GetLocalTime( &sys );
string y = doubleToString(sys.wYear);
string m = doubleToString(sys.wMonth);
string d = doubleToString(sys.wDay);
string ymd = y+"-"+m+"-"+d;

因为获取的是一个double值,您得对其时间强制类型转换

string doubleToString(double num)
{ //强制类型转换 double强制转换为string类型 
    stringstream ss;
    string str;
    ss << num;
    ss >> str;
    return str;
}

数据查询功能

LinkList SearchElemChar(LinkList L,int i,string e){ //思路,传递参数1,2,3,4,eg 1代表name,再分不同的方法在链表内循环查找操作 
 if (i == 1){ //查名字 
     while(L!= NULL){
         if(L->data.name == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
             cout << "未查到数据!"<<endl;
         }
 }else if(i == 2){//查生日 
     while(L!= NULL){
         if(L->data.birthday == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
         cout <<"未查到数据!"<<endl;
         }
 }
 else if(i == 3){//查地址 
     while(L!= NULL){
         if(L->data.adress == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
         cout <<"未查到数据!"<<endl;
         }
 }else if(i == 4){//查时间 
     while(L!= NULL){
         if(L->data.date == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
         cout <<"未查到数据!"<<endl;
         }
 }
 else if(i == 5){//查电话 
     while(L!= NULL){
         if(L->data.number == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
         cout <<"未查到数据!"<<endl;
         }
 }
 
} 

完整案例

//乐公第二周项目 实现基本通讯录存储结构 
//基础链表存储数据
#include <iostream>
#include <string>
#include<malloc.h> //system功能调用 
#include <windows.h> //使用本地系统API获取插入时间 
#include <sstream>
#define ERROR 0
#define OK 1
using namespace std;
typedef  int ElemType; /*定义表元素的类型*/
//结构体文件
typedef struct info{
    string number;
    string date;
    string name;
    string adress;
    string birthday; 
}A;
typedef struct LNode{
    A data; 
    struct LNode *next;
}LNode,*LinkList;

int InitList(LinkList &L){ //初始化链表 
    L = new LNode;
    L->next = NULL;
    return OK;
}
int ListInsert(LinkList &L,string name,string adress,string birthday,string date,string number){ //考虑使用数组来赋值 
    LinkList p; p= new LNode;
    p->data.name = name;
    p->data.adress = adress;
    p->data.date = date;
    p->data.birthday = birthday;
    p->data.number = number;
    p->next = L->next;
    L->next = p;
    return OK;
} 
//查找元素 (难题需要解决)
 
LinkList SearchElemChar(LinkList L,int i,string e){ //思路,传递参数1,2,3,4,eg 1代表name,再分不同的方法在链表内循环查找操作 
 if (i == 1){ //查名字 
     while(L!= NULL){
         if(L->data.name == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
             cout << "未查到数据!"<<endl;
         }
 }else if(i == 2){//查生日 
     while(L!= NULL){
         if(L->data.birthday == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
         cout <<"未查到数据!"<<endl;
         }
 }
 else if(i == 3){//查地址 
     while(L!= NULL){
         if(L->data.adress == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
         cout <<"未查到数据!"<<endl;
         }
 }else if(i == 4){//查时间 
     while(L!= NULL){
         if(L->data.date == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
         cout <<"未查到数据!"<<endl;
         }
 }
 else if(i == 5){//查电话 
     while(L!= NULL){
         if(L->data.number == e){
             return L; 
         }else{
         L = L->next;
         }
         }
         if(L = NULL){
         cout <<"未查到数据!"<<endl;
         }
 }
 
} 

LinkList SearchElemBefore(LinkList L,string e){ //删除结点必须返回前个结点的地址,这里查找前个结点 
     LinkList P; 
     while(L!= NULL){
         if(L->data.name == e){
             return P; 
         }else{
         P = L;
         L = L->next;
         }
         }
         if(L = NULL){
             return L; 
         }
} 
int ShowMenu(){ //主菜单 
    int a;
    cout<<"------欢迎您使用乐公通讯录系统!------"<< endl;
    cout <<"-----请根据功能输入对应的序号--------" <<endl; 
    cout <<"-----------1.新建联系人--------------" <<endl; 
    cout <<"--------2.查看所有联系人-------------" <<endl; 
    cout <<"--------3.修改选定联系人-------------" <<endl;
    cout <<"--------4.查询选定联系人-------------" <<endl;
    cout <<"--------5.删除选定联系人-------------" <<endl;
    cout <<"------------6.退出系统---------------" <<endl; 
    cout << "请您输入序号并按回车进入:" ; 
    cin >> a;
    return a;
}

string doubleToString(double num)
{ //强制类型转换 double强制转换为string类型 
    stringstream ss;
    string str;
    ss << num;
    ss >> str;
    return str;
}
void foreachelem(LinkList L){
    if(L->next == NULL){
        cout<<"通讯录里还没有联系人,快去新建一下吧~"<<endl; 
    }else{
    while(L->next!=NULL){
        L=L->next;
        cout<< "联系人姓名:" << L->data.name <<endl;
        cout<< "联系人电话:" << L->data.number<<endl;
        cout<< "联系人地址:" << L->data.adress <<endl;
        cout<< "联系人生日:" << L->data.birthday <<endl;
        cout<< "录入时间:" << L->data.date <<endl;
    }
    cout<< "\n";
}
//system("pause");
}
int serachsamename(LinkList L,string name){ //查找是否存在姓名相同的联系人 
    while(L->next!=NULL){
        L=L->next;
        if(L->data.name==name)return 0;
    }
    return 1;
} 
int main(){
    int i;
    LinkList L;
    InitList(L);
    while(i!=6){
        i = ShowMenu();
        if(i ==1){
            cout << "您选择了:新建联系人" <<endl; 
            string number;
            string date;
            string time;
            string name;
            string adress;
            string birthday; 
            cout << "请输入联系人姓名:"; 
            cin >> name;
             SYSTEMTIME sys; 
             GetLocalTime( &sys );
             string y = doubleToString(sys.wYear);
             string m = doubleToString(sys.wMonth);
             string d = doubleToString(sys.wDay);
             string ymd = y+"-"+m+"-"+d;
            int repeat = serachsamename(L,name); 
            if(repeat == 0){
                cout << "联系人姓名重复,请删除旧联系人或更改姓名!" << endl; 
             }else{
                 cout << "请输入联系人电话:"; 
                cin >> number;
            if(number.size()!=11){
                cout << "手机号输入有误,请大于11位!" << endl;    
            }else{
                cout << "请输入联系人生日:"; 
            cin >> birthday;
            cout << "请输入联系人地址:"; 
            cin >> adress;
                cout << "联系人于" << ymd;
                int ok;
            ok =  ListInsert(L,name,adress,birthday,ymd,number);
            if(ok == 1){
                cout << "日新建成功!" << endl; 
            }else{ 
            cout << "新建失败!" << endl;
            } 
            }
        }
            system("pause");
            system("cls");
        }else if(i==2){
            cout << "您选择了:遍历联系人" <<endl; 
            foreachelem(L);
            system("pause");
            system("cls");
            
        }else if(i==3){
            cout << "您选择了:修改选定联系人" <<endl; 
            cout <<"请输入要修改的联系人姓名:" ;
            string name;
            cin >> name;
            LinkList B;
            B = SearchElemChar(L,1,name);
             if(B){
                 system("cls");
                 cout << "联系人查找成功!姓名:" << B->data.name << endl; 
                 int select;
                 cout <<"---------修改姓名请输入1---------" << endl;
                cout <<"---------修改电话请输入2---------" << endl; 
                cout <<"---------修改生日请输入3---------" << endl; 
                cout <<"---------修改地址请输入4---------" << endl; 
                 cout <<"请根据序号输入对象的选项修改:" ;
                 cin >> select;
                 switch(select){
                     case 1: 
                     {    string name;
                    cout <<"请输入新姓名:"; 
                    cin >> name;
                    B->data.name = name;
                    cout <<"修改完成!" << endl;
                    break; 
                     }
                    case 2: {
                    string number;
                    cout <<"请输入新电话:"; 
                    cin >> number;
                    if(number.size()!=11){
                    cout << "手机号输入有误,请大于11位!" << endl;    
                    }else{
                    B->data.number = number;
                    cout <<"修改完成!" << endl;
                    }
                    break;
                    }
                     case 3:{
                         string birthday;
                         cout <<"请输入新生日:"; 
                         cin >> birthday;
                         B->data.birthday = birthday;
                        cout <<"修改完成!" << endl;
                        break;
                     }
                     case 4:{
                         string adress;
                         cout <<"请输入新地址:"; 
                         cin >> adress;
                         B->data.adress = adress;
                        cout <<"修改完成!" << endl;
                        break;
                     }
                     default:cout <<"序号输入错误,请重新输入!"<<endl; 
                 }
             }else{
                 cout << "未查找到联系人!请重新输入!" << endl; 
             }
              
            system("pause");
            system("cls");
        }else if(i==4){
            system("cls");
            cout << "您选择了:查询选定联系人" <<endl; 
                cout <<"---------根据姓名查询请输入1---------" << endl;
                cout <<"---------根据电话查询请输入2---------" << endl; 
                cout <<"---------根据生日查询请输入3---------" << endl; 
                cout <<"---------根据地址查询请输入4---------" << endl;
                int select;
                cout <<"请根据序号输入对象的进行查询:" ;
                 cin >> select;
                 switch(select){
                     case 1:{
                         cout <<"请输入要查询的联系人姓名:" ;
                        string name;
                        cin >> name;
                        LinkList B;
                        B = SearchElemChar(L,1,name);
                        if(B){
                            cout<<"查询成功!"<< endl; 
                            cout<<"联系人姓名:"<< B->data.name << endl;
                            cout<<"联系人电话:"<< B->data.number << endl;
                            cout<<"联系人生日:"<< B->data.birthday << endl;
                            cout<<"联系人地址:"<< B->data.adress << endl;
                            cout<<"插入日期:"<< B->data.date << endl;
                         }else{
                             cout<<"查询失败!请重新输入!"<< endl; 
                         }
                        break;
                     }
                     case 2:
                         {
                         cout <<"请输入要查询的联系人电话:" ;
                        string number;
                        cin >> number;
                        LinkList B;
                        B = SearchElemChar(L,5,number);
                        if(B){
                            cout<<"查询成功!"<< endl; 
                            cout<<"联系人姓名:"<< B->data.name << endl;
                            cout<<"联系人电话:"<< B->data.number << endl;
                            cout<<"联系人生日:"<< B->data.birthday << endl;
                            cout<<"联系人地址:"<< B->data.adress << endl;
                            cout<<"插入日期:"<< B->data.date << endl;
                         }else{
                             cout<<"查询失败!请重新输入!"<< endl; 
                         }
                        break;
                         }
                        case 3:{
                            cout <<"请输入要查询的联系人生日:" ;
                        string bd;
                        cin >> bd;
                        LinkList B;
                        B = SearchElemChar(L,2,bd);
                        if(B){
                            cout<<"查询成功!"<< endl; 
                            cout<<"联系人姓名:"<< B->data.name << endl;
                            cout<<"联系人电话:"<< B->data.number << endl;
                            cout<<"联系人生日:"<< B->data.birthday << endl;
                            cout<<"联系人地址:"<< B->data.adress << endl;
                            cout<<"插入日期:"<< B->data.date << endl;
                         }else{
                             cout<<"查询失败!请重新输入!"<< endl; 
                         }
                        break;
                        }
                        case 4:{
                        cout <<"请输入要查询的联系人地址:" ;
                        string ad;
                        cin >> ad;
                        LinkList B;
                        B = SearchElemChar(L,3,ad);
                        if(B){
                            cout<<"查询成功!"<< endl; 
                            cout<<"联系人姓名:"<< B->data.name << endl;
                            cout<<"联系人电话:"<< B->data.number << endl;
                            cout<<"联系人生日:"<< B->data.birthday << endl;
                            cout<<"联系人地址:"<< B->data.adress << endl;
                            cout<<"插入日期:"<< B->data.date << endl;
                         }else{
                             cout<<"查询失败!请重新输入!"<< endl; 
                         }
                        break;
                            break;
                        }
                     default:cout <<"序号输入错误,请重新输入!"<<endl; 
                 } 
            system("pause");
            system("cls");
        }else if(i==5){
            cout << "您选择了:删除联系人" <<endl; 
            string name;
            cout << "请输入联系人姓名:" <<endl; 
            cin >> name;
            LinkList D,P;
            P = SearchElemBefore(L,name); 
            if(P){
                D = P->next;
            P->next = D->next;
            delete D; //释放结点数据 
            cout << "删除成功!" <<endl;
            }else{
                cout<<"查询失败!未找到指定联系人!"<< endl; 
            }
            system("pause");
            system("cls");
        }else if(i==6){
            cout << "系统已退出,欢迎下次使用!" <<endl;
        }
        else{
            cout <<"输入异常,请重新选择输入!" <<endl;
            system("pause");
            system("cls");
        }
    } 
    return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C++ 实现的通讯录管理系统详解

    代码如下: #include<iostream> #include <sstream> using namespace std; #define Max 1000 //显示菜单函数 void showMenu() { cout << "************************" << endl; cout << "**** 1.添加联系人 ****" << endl; cout <

  • C++双向链表实现简单通讯录

    本文实例为大家分享了C++双向链表实现简单通讯录的具体代码,供大家参考,具体内容如下 #include<iostream> #include<fstream> #include <stdlib.h> #include<string> using namespace std; typedef struct Directory { string Name; string Mobile; string Wechatnumber; string STREET; st

  • C++容器vector实现通讯录功能

    之前学习C语言的时候,用链表实现过通讯录的基本功能.最近写了一个C++版本的通讯录,参考代码如下所示. main.cpp /***************************************************** Copyright (C): 2017-2018 File name : main.cpp Author : Zhengqijun Date : 2017年02月12日 星期日 16时47分52秒 Description : 主函数 Funcion List : ma

  • C++链表实现通讯录管理系统

    用数据结构里面线性结构的链表实现,供大家参考,具体内容如下 文件操作未写 有登录操作,复制源码需要更改登录模块的密码文件存放位置 使用VS2017编译器需要保留开头: #define _CRT_SECURE_NO_WARNINGS #define _CRT_SECURE_NO_WARNINGS #include "iostream" #include "cstdio" #include "fstream" #include "stdli

  • C++实现链表版本通讯录

    本文实例为大家分享了C++实现链表版本通讯录的具体代码,供大家参考,具体内容如下 #include <iostream> #include <string> using namespace std; class Address; class Contact{ private: string name; string sex; string tel; string QQ; string address; string addition; Contact *next; public:

  • C++实现通讯录管理系统

    本文实例为大家分享了C++通讯录管理系统的具体代码,供大家参考,具体内容如下 #include<iostream> #include<string> using namespace std; #define MAX 1000 struct Person { string m_Name; int m_Sex; int m_Age; string m_Phone; string m_Addr; }; struct Addressbooks { struct Person personA

  • C++实现简单通讯录管理系统

    本文实例为大家分享了C++实现简单的通讯录管理系统的具体代码,供大家参考,具体内容如下 一.代码 #include <iostream> #include <string> #include <cstring> #include <fstream> using namespace std; //自定义一个联系人结点类型 typedef struct node1 {     string name;        //姓名     string tel;  

  • C++简易通讯录系统实现流程详解

    目录 实现功能 定义通讯录和通讯录人员结构体 实现通讯录输入菜单 1.定义菜单函数: 2.主函数循环体中循环展示菜单信息 实现增删改查和清空通讯录功能 运行截图展示 实现功能 提示:这里可以添加本文要记录的大概内容: 通过c++语法的学习,实现一个简易的通讯录功能,具体实现功能如下: 添加联系人:向通讯录中添加联系人,信息包括(姓名.性别.年龄.联系电话.家庭住址),做多记录1000人 显示联系人:显示通讯录中所有联系人信息 删除联系人:按照姓名进行删除联系人 查找联系人:按照姓名进行查找联系人

  • C++实现简易通讯录

    本文实例为大家分享了C++实现简易通讯录的具体代码,供大家参考,具体内容如下 #include <iostream> #include <string> #define MAX 1000 using namespace std; // 设计联系人的结构体 struct Person { string m_Name; int m_Sex; // 1.男 2 女 int m_Age; string m_Phone; string m_Addr; }; // 设计通讯录的结构体 stru

  • C++实现简单通讯录

    本文实例为大家分享了C++实现简单通讯录的具体代码,供大家参考,具体内容如下 说明: 1 程序中运用到两个类,一个是Person类,另一个是List类.前者存储用户信息,后者主要用于操作,如增删改查等.但由于本程序中没有涉及到太复杂的功能,用户信息可以由一个简单的结构体表示,但是为了以后拓展方便,和达到学习运算符重载的目的,还是使用了类. 2 List类中的Reflush()方法用户刷新文件内容,即每次修改了vector后要将最新内容写入到文件.因此增删改操作中都要调用该操作,这种方法在数据库开

随机推荐