| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 302 人关注过本帖
标题:类的链表问题和执行过程
只看楼主 加入收藏
yang0401
Rank: 2
等 级:论坛游民
帖 子:84
专家分:57
注 册:2011-5-23
结帖率:69.23%
收藏
已结贴  问题点数:17 回复次数:1 
类的链表问题和执行过程
程序代码:
#include <iostream.h>
enum {k1,k2,k3};
class data
{
public:
    data(int val):myval(val){cout << "数据结点建立\n";}
    ~data(){;}
    int compare(const data&);
    void show(){cout << myval << "\t";}
private:
    int myval;
};
int data::compare(const data& otherdata)
{
    cout << "data的compare函数\n";
    if(myval < otherdata.myval)
        return k1;
    if(myval > otherdata.myval)
        return k2;
    else
        return k3;
}
class node;
class inode;
class tnode;
class hnode;

class node
{
public:
    node(){cout << "node的构造函数\n";}
    virtual ~node(){}
    virtual node* insert(data *thedata)=0;
    virtual void show()=0;
private:
};
class inode:public node
{
public:
    inode(data* thedata,node *next);
    ~inode(){delete mynext;delete mydata;}
    virtual node* insert(data *thedata);
    virtual void show(){mydata->show();mynext->show();}
private:
    data* mydata;
    node* mynext;
};
inode::inode(data* thedata,node *next)
{
    mydata=thedata;
    mynext=next;
    cout << "inode的构造函数\n";
}
node* inode::insert(data *thedata)
{
    cout << "i的insert\n";
    int result=mydata->compare(*thedata);
    switch(result)
    {
    case k3:

    case k2:
        {
            inode* datanode=new inode(thedata,this);
            return datanode;
        }
    case k1:
        mynext=mynext->insert(thedata);
        return this;
    }
    return this;
}
class tnode:public node
{
public:
    tnode(){cout << "t的构造函数\n";}
    ~tnode(){}
    virtual node*insert(data* thedata);
    virtual void show(){}
private:

};
node* tnode::insert(data* thedata)
{
    inode* datanode=new inode(thedata,this);
    cout << "tnode的insert\n";
    return datanode;
}
class hnode:public node
{
public:
    hnode();
    ~hnode(){delete mynext;}
    virtual node*insert(data* thedata);
    virtual void show(){mynext->show();}
private:
    node* mynext;
};
hnode::hnode()
{
    mynext=new tnode;               //因为mynext被初始化为tnode;所以mynext->insert调用的是tnode的insert虚函数.
    cout << "honde的构造函数\n";
}
node* hnode::insert(data* thedata)
{
    mynext=mynext->insert(thedata);
    cout << "hnode的insert\n";
    return this;
}
class linklist
{
public:
    linklist();
    ~linklist(){delete myhead;}
    void insert(data* thedata);
    void show(){myhead->show();}
private:
    hnode *myhead;
};
linklist::linklist()
{
    myhead=new hnode;
    cout << "link的构造函数\n";
}
void linklist::insert(data* pdata)
{
    myhead->insert(pdata);
    cout << "link的insert\n";
}
int main()
{
    data* pdata;
    int val;
    linklist ll;
    for(;;)
    {
        cout << "what value?(0 to top)";
        cin >>val;
        if(!val)
            break;
        pdata=new data(val);
        ll.insert(pdata);
    }
    ll.show();
    return 0;
}
不太明白c++是怎么建立链表的,能详细讲解下执行过程吗?
搜索更多相关主题的帖子: color 
2012-05-18 15:38
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
收藏
得分:12 
回复 楼主 yang0401
个人感觉比c写起来麻烦  但比c好用

自己多试着编些例子   较容易理解
2012-05-18 17:48
快速回复:类的链表问题和执行过程
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.079225 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved