2 gdjysx gdjysx 于 2013.05.28 21:39 提问

哈希表电话本问题求大神解决

各位大神,我不知道要怎么把这些代码给组合起来

void InHash(pointer p[])
{

    pointer t=new HsNode();
    cout<<"输入用户姓名:";
    cin>>t->Name;

    cout<<"输入用户号码:";
    cin>>t->PhoneNumber;

    cout<<"输入用户地址:";
    cin>>t->Address;
    t->next=NULL;

    int a=Sum(t->PhoneNumber);
    int b=a%7;
    if(p[b]==NULL)
    {
        p[b]=t;
    }
    else
    {
        pointer r;
        r=p[b];
        while(r->next!=NULL)
        {
            r=r->next;
        }
        r->next=t;
    }
}
void OutHash(pointer p[],char ch[])
{
    int a=Sum(ch);
    int b=a%7;
    pointer r=p[b];
    if(!strcmp(r->PhoneNumber,ch))
    {
        p[b]=r->next;
        delete r;
        return;
    }
    pointer s=r;
    while(1)
    {
        r=r->next;
        if(!strcmp(r->PhoneNumber,ch))
        {
            s->next=r->next;
            delete r;
            return;
        }
        else
        {
            s=r;
        }
    }
}
void SearchHash(pointer p[],char ch[])
{
    int a=Sum(ch);
    int b=a%7;
    pointer r=p[b];
    if(r==NULL)
    {
        cout<<"没有该号码。"<<endl;
        return;
    }
    if(!strcmp(r->PhoneNumber,ch))
    {
        cout<<"其他信息为:"<<endl;
        cout<<"姓名为:"<<r->Name<<endl;
        cout<<"地址为:"<<r->Address<<endl;
        return;
    }
    if(r!=NULL&&r->next==NULL)
    {
        cout<<"没有该号码。"<<endl;
        return;
    }
    pointer s=r;
    while(1)
    {
        r=r->next;
        if(!strcmp(r->PhoneNumber,ch))
        {
            cout<<"其他信息为:"<<endl;
            cout<<"姓名为:"<<r->Name<<endl;
            cout<<"地址为:"<<r->Address<<endl;
            return;
        }
        else if(r->next==NULL)
        {
            cout<<"没有该号码。"<<endl;
            return;
        }
        else
        {
            s=r;
        }
    }
}

1个回答

lyyybz
lyyybz   Rxr 2016.08.19 10:50

请问你的问题解决了么,我碰到和你一样的问题!

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
哈希表的应用之电话本
用哈希表编程实现一个电话本,电话本中记录的数据项为(姓名拼音,电话),例如(LiSi,17012345678)。   要求: 1、用面向对象的方法编程实现电话本类; 2、使用一维数组实现哈希表; 3、取姓名拼音中第一个字母在字母表中的序号作为哈希函数; 4、使用线性探测再散列的方法处理冲突。   注意: 1、拼音字母不区分大小写 2、输入输出格式为: (输入)WangSan,
散列表(哈希函数)电话簿通讯录
输入学生信息保存到文件,然后可通过姓名 电话号码多次查询该学生信息
利用哈希表实现11位电话号码的快速排序
利用Hash散列表实现11位移动电话号码的排序
2016BIT小学期——电话号码问题(哈希+位运算)
1.题目描述: 商业单位需要容易记忆的电话号码,有一些方法可以让电话号码变得更容易记忆。譬如,可以把电话号码写成单词或短语,如 MON-GLOP 可以代表滑铁卢大学的电话。有时仅仅是把号码的一部分写成单词,如打 310-GINO 便可向 GINO 比萨饼店定购比萨。另一种让电话号码容易记忆的方法是将数字用一种容易记的方式组合起来,譬如 3-10-10-10 也
左菜单侧滑
侧滑的一个例子 求大神解决下2次选中侧滑标签列表失焦问题
最小堆解决topK问题
package dataStructer; public class MinHeap { // 堆的存储结构 - 数组 private int[] data; // 将一个数组传入构造方法,并转换成一个小根堆 public MinHeap(int[] data) { this.data = data; buildHeap(); } // 将数组转换成最小堆 priv
C++散列表实现电话本存储及查找功能
利用开散列表实现电话本存储和查找功能,可用于计算机专业学生数据结构课程设计
Top K 算法详解(哈希表Hash的使用)
Top K 算法详解(哈希表Hash的使用)
哈希表的设计与实现(关于电话本的额查找)
关于哈希表的设计与实现!c数据结构课程设计题目!电话本的查找。
求大神解决这个问题
学长做的一个比较古老的项目,部署后,隔一段时间数据库就会连接不上,求如何解决:[org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is com.mysql.jdbc.CommunicationsException: Communicat...