数据结构--BlockQuery,HashQuery,通讯录

本文介绍了一个使用 C++ 实现的联系人信息管理系统。系统包括两个主要部分:ContactList 类用于维护联系人的列表,并提供添加、更新、删除和查询等功能;HashFind 类实现了基于哈希表的快速查找功能。此外,系统还支持按首字母分块查询,提高了搜索效率。

#include <iostream>
#include<list>
using namespace std;
 //jianli Hash class
 //
 class ContactInfo
 {
 public:
    string name;
    string phoneNum;
    string email;
 ContactInfo(string n,string p,string e)
 {
     name=n;
     phoneNum=p;
     email=e;
 }
 ContactInfo()
 {

 }
 string getName()
 {
     return name;
 }
 string getPhoneNum()
 {
    return phoneNum;
 }
 string getEmail()
 {
     return email;
 }
 int getkey()
 {
     int num=0;
     for(int i=0;i<name.size()&&(name[i]!='\0');i++)
     {
            num+=name[i];
     }
     return num;
 }
 bool operator==(ContactInfo &c2)
 {
     return name==c2.name;
 }
 bool operator<(ContactInfo &c2)
 {
     return name<c2.name;
 }
 };
 class HashFind{
 public:
     list<ContactInfo> *p;
     int length;
     HashFind(int n)
     {
        p=new list<ContactInfo>[n];
        length=n;
     }
     int Hash(int x)
     {
         return (x)%length;
     }
     void buildHash(list<ContactInfo> &ll)
     {

           list<ContactInfo>::iterator iter;

                for(iter=ll.begin();iter!=ll.end();iter++)
                    {

                            p[Hash((*iter).getkey())].push_back((*iter));
                    }
     }
     ContactInfo find_contact(ContactInfo a)
     {

         list<ContactInfo>::iterator iter;

                for(iter=p[Hash(a.getkey())].begin();iter!=p[Hash(a.getkey())].end();iter++)
                    {

                           if(a==(*iter))
                           {
                                cout<<"name: "<<(*iter).name<<" phone: "<<(*iter).phoneNum<<" Email "<<(*iter).email<<endl;
                               return a;
                           }
                    }

     }



 };

 class ContactList
 {
     public:
     list<ContactInfo> contacts;

     int blockInfo[26][2];
     int length;
     ContactList(int size)
     {
            for(int i=0;i<26;i++)
                for(int j=0;j<2;j++)
            {
                blockInfo[i][j]=0;
                length=size;
            }
     }
     bool addContact(string name,string phonenum,string email)
     {
         int pos=0;
         ContactInfo contact(name,phonenum,email);
         while(pos<contacts.size())
         {
             list<ContactInfo>::iterator iter;
             int i=0;
             for(iter=contacts.begin();iter!=contacts.end();iter++)
             {
                      if(i==pos)
                      {
                          break;
                      }
                       i++;
             }
             if(*iter==contact)
             {
                 break;
             }
             else if(*iter<contact)
             {
                 pos++;
             }
             else
             {
                 contacts.insert(iter,contact);
                 break;
             }

        }
     }
/*bool removeContact(string name,string phonenum,string email)
     {

         ContactInfo contact(name,phonenum,email);
list<ContactInfo>::iterator iter;

             for(iter=contacts.begin();iter!=contacts.end();iter++)
             {
                      if((*iter)==contact)
                      {
                            break;
                      }
             }
            contacts.remove(contact);
            return true;

     }   */
 bool UpdateContact(string name,string phonenum,string email)
     {

         ContactInfo contact(name,phonenum,email);

list<ContactInfo>::iterator iter;
             for(iter=contacts.begin();iter!=contacts.end();iter++)
             {
                      if((*iter)==contact)
                      {
                            break;
                      }
             }
          (*iter).phoneNum=contact.phoneNum;
          (*iter).email=contact.email;

     }
 bool DeleteContact(string name,string phonenum,string email)
     {

                ContactInfo contact(name,phonenum,email);

                list<ContactInfo>::iterator iter;
             for(iter=contacts.begin();iter!=contacts.end();iter++)
             {
                      if((*iter)==contact)
                      {
                          iter= contacts.erase(iter);
                            break;
                      }
             }


     }
    void showList()
    {
        list<ContactInfo>::iterator iter;
        cout<<"-------------------ContactLists--------------"<<endl;
        for(iter=contacts.begin();iter!=contacts.end();iter++)
             {
                      cout<<"name: "<<(*iter).name<<" phone: "<<(*iter).phoneNum<<" Email "<<(*iter).email<<endl;
             }
        cout<<"-------------------ContactLists--------------"<<endl;
            }
     int blockQuery(string name)
     {

         int I=97;
         while(I<123)
         {
             int start=0;
             int end=0;
             start=end;
             int flag1=1;
             int flag2=1;
             list<ContactInfo>::iterator iter;
             while(start<contacts.size()&&flag1)
             {

                int i=0;
                for(iter=contacts.begin();iter!=contacts.end();iter++)
                    {

                         if((*iter).name[0]<I)
                         {
                            start++;
                            flag1=1;
                         }
                     else
                      {
                        flag1=0;
                        break;
                      }
                }

             }

             end=(start);
            while(end<contacts.size()&&flag2)
             {


                for(;iter!=contacts.end()&&(end<contacts.size());iter++)
                {
                         if((*iter).name[0]==I)
                           {
                                end++;
                                flag2=1;
                           }
                    else  if(((*iter).name[0]!=I))
                    {
                       flag2=0;
                       break;
                   }

               }

             }

             blockInfo[I-97][0]=start;
             blockInfo[I-97][1]=end;

             I++;
         }
         int nam=(int)name[0];

         int s=blockInfo[nam-97][0];
         int e=blockInfo[nam-97][1];

         int ss=0;
         list<ContactInfo>::iterator itera;
         list<ContactInfo>::iterator is;
         list<ContactInfo>::iterator ie;
         for(itera=contacts.begin();itera!=contacts.end();itera++)
         {
                       if(ss==s)
                       {

                           is=itera;
                       }
                       if(ss==e)
                       {

                           ie=itera;
                           break;
                       }
                       ss++;
         }

             for(itera=is;itera!=ie;itera++)
         {

                      if((*itera).name==name)
                      {
                          cout<<"name: "<<(*itera).name<<" phone: "<<(*itera).phoneNum<<"Email "<<(*itera).email<<endl;
                          return true;
                      }
         }
         cout<<"end"<<endl;
         return false;

     }

 };
 void show_table()
 {

 }
int main()
{
    ContactList a(10);
    ContactInfo b("sss","sss","sss");
    a.contacts.push_back(b);
    a.addContact("abb","165","123456");
    a.addContact("abc","156","123456");
    a.addContact("cdc","187","123456");
    a.addContact("bcd","163","123456");
    a.showList();
    cout<<"--------blockQuery--sss-------"<<endl;
    a.blockQuery("sss");
    cout<<"--------update--sss-------"<<endl;
    a.UpdateContact("sss","1566653","13006666@qq.com");
    a.showList();
    cout<<"--------delete--abc-------"<<endl;
    a.DeleteContact("abc","156","123456");
    a.showList();
     HashFind h(10);

     cout<<"--------HashQuery--abb-------"<<endl;
     h.buildHash(a.contacts);
     ContactInfo c("abb","122","123");
     h.find_contact(c);

    return 0;
}

#include #include #include using namespace std; #define NULL 0 unsigned int key; //用来输入/输出文件流类 unsigned int key2; //key和key2分别是用做了电话号码和姓名的关键字 int *p; struct node //新建节点(用户姓名、地址、电话号码、指向下一个结点的指针 ) { char name[8],address[20]; char num[11]; node * next; }; typedef node* pnode; typedef node* mingzi; //声明了名字和电话两个指针 node **phone; node **nam; node *a; void hash(char num[11]) //以电话号码为关键字建立哈希函数 { int i = 3; key=(int)num[2]; while(num[i]!=NULL) { key+=(int)num[i]; i++; } key=key%20; } void hash2(char name[8]) //姓名为关键字建立哈希函数 { int i = 1; key2=(int)name[0]; while(name[i]!=NULL) { key2+=(int)name[i]; i++; } key2=key2%20; } //强制类型转换,将用户名的每一个字母的ASCLL码值相加并且除以20后的余数 node* input() //输入节点信息 ,建立结点,并将结点的next指针指空 { node *temp; temp = new node; temp->next=NULL; cout<<"输入姓名:"<>temp->name; cout<<"输入地址:"<>temp->address; cout<<"输入电话:"<>temp->num; return temp; } //对于指针类型返回的是地址 int apend() //添加节点 { node *newphone; node *newname; newphone=input(); newname=newphone; newphone->next=NULL; newname->next=NULL; hash(newphone->num); //利用哈希函数计算出对应关键字的存储地址 hash2(newname->name); newphone->next = phone[key]->next; //利用电话号码为关键字插入 phone[key]->next=newphone; //是采用链地址法,拉链法处理冲突的散列表结构 newname->next = nam[key2]->next; //利用用户名为关键字插入 nam[key2]->next=newname; return 0; } void create() //新建节点 { int i; phone=new pnode[20]; //动态创建对象数组,C++课本P188页 for(i=0;inext=NULL; } } void create2() //新建节点 { int i; nam=new mingzi[20]; for(i=0;inext=NULL; } } void list() //显示列表 { int i; node *p; for(i=0;inext; while(p) { cout<name<<'_'<address<<'_'<num<next; } } } void list2() //显示列表 { int i; node *p; for(i=0;inext; while(p) { cout<name<<'_'<address<<'_'<num<next; } } } void find(char num[11]) //在以电话号码为关键字的哈希表中查找用户信息 { hash(num); node *q=phone[key]->next; while(q!= NULL) { if(strcmp(num,q->num)==0) break; q=q->next; } if(q) cout<name<<"_" <address<<"_"<num<<endl; else cout<<"无此记录"<next; while(q!= NULL) { if(strcmp(name,q->name)==0) break; q=q->next; } if(q) cout<name<<"_" <address<<"_"<num<<endl; else cout<<"无此记录"<<endl; } void save() //保存用户信息 { int i; node *p; for(i=0;inext; while(p) { fstream iiout("out.txt", ios::out); //创建一个文件流对象:iiout iiout<name<<"_"<address<<"_"<num<next; } } } void menu() //菜单 { cout<<" 哈希表通讯录"<<endl; cout<<" 0.添加记录"<<endl; cout<<" 2.姓名散列"<<endl; cout<<" 3.查找记录"<<endl; cout<<" 4.号码散列"<<endl; cout<<" 5.清空记录"<<endl; cout<<" 6.保存记录"<<endl; cout<<" 7.退出系统"<>sel; if(sel==3) { cout<<"8姓名查询" <<endl;cout<<"9号码查询"<>b; if(b==9) {cout<<"请输入电话号码:"<>num; cout<<"输出查找的信息:"<<endl; find(num); } else {cout<<"请输入姓名:"<>name; cout<<"输出查找的信息:"<<endl; find2(name);}} if(sel==2) {cout<<"姓名散列结果:"<<endl; list2();} if(sel==0) {cout<<"请输入要添加的内容:"<<endl; apend();} if(sel==4) {cout<<"号码散列结果:"<<endl; list(); } if(sel==5) {cout<<"列表已清空:"<<endl; create();create2();} if(sel==6) { cout<<"通信录已保存:"<<endl; save();} if(sel==7) return 0; } return 0; }
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值