4.使用多态机制实现通用链表

.

//使用多态实现统一的链表
//链表的释放


#include <iostream>
#include <assert.h>
#include <string.h>
using namespace std;

class Object
{
public:
    Object()
    {}
    virtual ~Object()
    {}
public:
    virtual void Print()const = 0;//接口
    virtual bool Compare(Object* pb)const = 0;


};



class List;
class ListNode
{
    friend class List;
public:
    ListNode()
    {
        data = NULL;
        next = NULL;
    }
    ListNode(Object *pobj)
    {
        data = pobj;
        next = NULL;
    }
    ~ListNode()
    {
        delete data;
    }
private:
    Object *data;
    ListNode *next;
};

class List
{
public:
    List()
    {
        Head = Tail = new ListNode;//带头结点的链表
    }
    ~List()
    {
        ListNode *p = Head->next;
        while(p != NULL)
        {
            Head->next = p->next;
            delete p;
            p = Head->next;
        }
        delete Head;
        Head = Tail =NULL;
    }
public:
    void Push_back(Object *p)//尾插
    {
        ListNode *s = new ListNode(p);
        assert(s != NULL);
        Tail->next = s;//?
        Tail = s;
    }
    void PrintList()const
    {
        ListNode *p = Head->next;
        while( p != NULL)
        {
            p->data->Print();//多态
            p = p->next;
        }
        cout<<"Nul."<<endl;
    }

    void InsertOrder(Object *pb)//按升序插入
    {
        ListNode *s = new ListNode(pb);
        ListNode *q = Head;
        ListNode *p = Head->next;
        while(p!=NULL && p->data->Compare(s->data))
        {
            q = p;
            p = p->next;
        }
        s->next = p;
        q->next = s;
        if(p == NULL)
            Tail = s;
    }

private:
    ListNode *Head;
    ListNode *Tail;
};


class IntObject:public Object
{
public:
    IntObject(int d = 0):data(d)
    {

    }
    ~IntObject()
    {

    }
public:
    virtual void Print()const
    {
        cout<<data<<"-->";
    }
    virtual bool Compare(Object* pb)const
    {

        IntObject *pi = dynamic_cast<IntObject*>(pb);
        assert(pi != NULL);
        return data < pi->data;
    }

private:
    int data;
};

class StringObject:public Object
{
public:
    StringObject(const char *str)
    {
        if(str == NULL)
        {
            data = new char[1];
            data[0] = '\0';
        }
        else
        {
            data = new char[strlen(str)+1];
            strcpy(data,str);
        }
    }

    ~StringObject()
    {
        delete []data;
        data = NULL;
    }

public:
    virtual void Print() const
    {
        cout<<"\""<<data<<"\"-->";
    }

    virtual bool Compare(Object* pb)const
    {

        StringObject *ps = dynamic_cast<StringObject*>(pb);
        assert(ps != NULL);
        int result;
        result = strcmp(data,ps->data);
        if(result >=0)
            return false;
        return true;
    }

private:
    char *data;

};




int main()
{
/*
    List mylist;
    for(int i=1;i<=5;++i)
    {
        IntObject *pi = new IntObject(i);
        mylist.Push_back(pi);
    }
    mylist.PrintList();
*/
/*
    List youlist;
    char *str[] = {"xyz","abcd","ffffff","udiaa","ddddddd"};
    for(int j = 0;j<5;++j)
    {
        StringObejct *ps = new StringObejct(str[j]);
        youlist.Push_back(ps);
    }
    youlist.PrintList();
*/

    List mylist;
    IntObject *pi = new IntObject(3);
    mylist.InsertOrder(pi);
    pi = new IntObject(2);
    mylist.InsertOrder(pi);
    pi = new IntObject(5);
    mylist.InsertOrder(pi);
    pi = new IntObject(4);
    mylist.InsertOrder(pi);
    pi = new IntObject(1);
    mylist.InsertOrder(pi);
    mylist.PrintList();


/*
    List youlist;
    char *str[] = {"xyz","abcd","ffffff","udiaa","ddddddd"};
    for(int j = 0;j<5;++j)
    {
        StringObject *ps = new StringObject(str[j]);
        youlist.InsertOrder(ps);
    }
    youlist.PrintList();
*/
    return 0;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值