异质链表

#include <cstdlib>
#include <iostream>
/*
  Name: 异质链表 
  Copyright: 1.0
  Author: 田保兴 
  Date: 01/11/13 17:21
  Description:  Graduate(研究生)继承类Student,Student(学生)继承 Person,Person是基础类。
  List保存person。 
*/

using namespace std;

//类声明完毕应该加分号
class Person{//最基础类 
      private:
              friend class List;
      protected:
                char name[20]; //姓名 
                int age;//年龄 
                char address[20];//地址 
                char tel[20];//手机号码 
                static Person *ptr;
                Person *next;
      public:
             Person(char *,int,char *,char *);
             virtual void print(); //virtual 虚函数 ,virtual主要是为了以后能实现它。主要是为了继承 
             virtual void insert()=0;
      }; 
class Student:public Person{ //学生 
      private:
              friend class List;
      protected:
              int level;//年级 
              char school[20];//学校 
      public:
             Student(char *,int ,char *,char *,int ,char *); 
             void print();
             void insert();
      }; 
class Graduate:public Student{//研究生 
      private:
              friend class List;
              char field[20] ;//研究领域
      public: 
              Graduate(char *,int ,char *,char *,int ,char *,char *); 
              void print();
              void insert();
      };

class List {//异质链表
      private:
              Person *root;//根节点 
      public:
             List(){
                    root=0;
                    } 
             void add(Person *node);
             void remove(char *name); 
             void show();
      
      };
Person::Person(char *name,int age,char *address,char *tel){
                    strcpy(Person::name,name);
                    Person::age=age;
                    strcpy(Person::address,address);
                    strcpy(Person::tel,tel);  
                    next=0;                  
                    }
void Person::print(){
       cout<<"\nname:"<<name<<"\n";
       cout<<"age:"<<age<<"\n";
       cout<<"address:"<<address<<"\n";
       cout<<"telephone number:"<<tel<<"\n";
     }
Student::Student(char *name,int age,char *address,char *tel,int level,char *school):
Person(name,age,address,tel)
{
    Student::level=level;
    strcpy(Student::school,school);  
    
}//构造函数
void Student::print(){
       Person::print();
       cout<<"level:"<<level<<"\n";
       cout<<"school :"<<school<<"\n";
     }
void Student::insert()
{
    ptr=new Student(name,age,address,tel,level,school);
}
Graduate::Graduate(char *name,int age,char *address,char *tel,int level,char *school,char *field):
Student(name,age,address,tel,level,school)
{
    strcpy(Graduate::field,field);  
    
}//构造函数
void Graduate::print(){
       Student::print();
       cout<<"field :"<<field<<"\n";
     }
void Graduate::insert()
{
    ptr=new Graduate(name,age,address,tel,level,school,field);
}

void List::add(Person *node)
{
    char key[20];
    strcpy(key,node->name);
    Person *curr_node=root;//Person类是List类的友元,故可以直接访问
    Person *previous=0;
    while(curr_node!=0&&strcmp(curr_node->name,key)<0)
    {
        previous=curr_node;
        curr_node=curr_node->next;
    }
    node->insert();
    node->ptr->next=curr_node;
    if(previous==0)
    {
        root=node->ptr;//根指针指向新节点
    }
    else
    {
        previous->next=node->ptr;
    }

}

void List::remove(char *name)
{
    Person *curr_node=root;
    Person *previous=0;//记录之前结点
    while(curr_node!=0&&strcmp(curr_node->name,name)!=0)
    {
        previous=curr_node;
        curr_node=curr_node->next;
    }

    if(curr_node!=0&&previous==0)
    {
        root=curr_node->next;
        delete curr_node;
    }//是根结点的情况
    else if(curr_node!=0&&previous!=0)
    {
        previous->next=curr_node->next;
        delete curr_node;
    }
}

void List::show()
{
    Person *cur=root;
    while(cur!=0)
    {
        cur->print();
        cur=cur->next;
    }
}


Person *Person::ptr=0;      
int main(int argc, char *argv[])
{
    List list;
    Student stu("田强强",25,"河北","188107485",3,"北航");
    list.add(&stu);
    
    Graduate gra("田保兴",25,"北京","18810743",3,"北京航空航天大学","大数据");
    list.add(&gra);
    
    list.show(); 
    system("PAUSE");
    return EXIT_SUCCESS;
}

转载于:https://my.oschina.net/winHerson/blog/173488

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值