实现异质单链表类

大学人员分为两类,大学人员分为两类,一类是教学人员,一类是非教学人员。这两类人员的信息管理系统中一部分信息内容不同,另一部分信息内容相同。设教学人员的信息包括姓名、年龄和专业编号;非教学人员的信息包括姓名、年龄和业绩评定。现邀请设计一个能同时存储学习教学人员和非教学人员的异质单链表类。

 

#include <string.h>
#include <iostream>
#include <stdlib.h>
using namespace std;
class DlinList;

class Person{     //建立一个基类,不同人员分别继承Person类
    friend class DlinList;
protected:
    string name;
    int age;
    Person* next;
    static Person* point;
public:
    Person(string nm,int ag);
    ~Person(){}

    virtual void print();
};

Person::Person(string nm,int ag)
{
    name=nm;
    age=ag;
    next=NULL;
}

void Person::print()
{
    cout<<"name:"<<name<<endl;
    cout<<"age:"<<age<<endl;
}
class Professor:public Person  //教学人员类
{
private:
    int SpecialNo;
public:
    Professor(string nm,int ag,int sn):Person(nm,ag)
    {SpecialNo=sn;}

    ~Professor(){};

    void print();
};

void Professor::print()
{
    Person::print();
    cout<<"zhuangye "<<SpecialNo<<endl;
}

class Staff:public Person   //非教学人员类
{
private:
    char comment;
public:
    Staff(string nm,int ag,char cm):Person(nm,ag)
    {comment=cm;}
    ~Staff(){}

    void print();
};


void Staff::print()
{
    Person::print();
    cout<<"yeji "<<comment<<endl;
}

class DlinList   //一个链表类,实现各种操作
{
private:
    Person* head;
    int size;
public:
    DlinList():head(NULL),size(0){}
    ~DlinList();

    Person* index(int pos);    //定位
    void insert(Person* p,int pos);  //插入
    void Delete(int pos);      //删除
    void print();
};

DlinList::~DlinList()
{
    Person* curr,*prev;
    curr=head;
    while(curr!=NULL)
    {
        prev=curr;
        curr=curr->next;
        delete prev;
    }
    size=0;
}

Person* DlinList::index(int pos)
{
    if(pos==-1)
        return head;
    Person* curr=head;
    int i=0;
    if(curr!=NULL&&i<pos)
    {
        curr=curr->next;
        i++;
    }
    return curr;
}

void DlinList::insert(Person* p,int pos)
{
    Person* prev=index(pos-1);

    Person::point=p;
    if(pos==0)
    {
        Person::point->next=head;
        head=Person::point;    
    }
    else
    {
        Person::point->next=prev->next;
        prev->next=Person::point;

    }
    size++;
}

void DlinList::Delete(int pos)
{
    if(size==0)
    {
        cout<<"link is empty"<<endl;
        exit(1);
    }
    Person* kill;
    Person* prev=index(pos-1);
    if(pos==0)
    {kill=prev;
    head=head->next;
    }
    else
    {
        kill=prev->next;
        prev->next=prev->next->next;
    }
    delete kill;
    size--;
}

void DlinList::print()
{
    Person* curr=head;
    while(curr!=NULL)
    {
        curr->print();
        curr=curr->next;
    }
}

Person* Person::point=NULL;

int main()
{
    DlinList personList;

    Person *p1=new Professor("zhangsan",40,2);
    Person *p2=new Professor("lisi",50,4);
    Person *p3=new Staff("wangwu",30,'A');
    Person *p4=new Staff("zhaoliu",30,'A');

    personList.insert(p1,0);
    personList.insert(p2,1);
    personList.insert(p3,2);
    personList.insert(p4,3);

    personList.Delete(0);
    personList.print();
    
}

 

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 基于异质图嵌入的跨域推荐可以通过以下步骤实现:首先,将不同域的数据表示为异质图,然后使用图嵌入算法将异质图嵌入到低维向量空间中,最后通过相似度计算实现跨域推荐。具体实现可以使用深度学习模型,如图卷积网络(GCN)等。 ### 回答2: 基于异质图嵌入的跨域推荐是指在不同域或领域下的推荐系统中,利用异质图嵌入方法来实现推荐任务。 要实现基于异质图嵌入的跨域推荐,可以按照以下步骤进行: 1. 数据准备:收集并整理不同域或领域的相关数据,包括用户、物品和关系信息。这些数据应该以异质图的形式进行表示,即图中的节点代表不同型的实体,边代表不同型的关系。 2. 异质图构建:根据数据准备的异质图,构建对应的图结构,包括节点和边的型,以及它们之间的关系。例如,可以将用户和物品分别作为一种节点型,用户和物品之间的交互行为作为一种关系型。 3. 异质图嵌入:利用异质图嵌入方法将异质图中的节点和边映射到低维向量空间中。常用的异质图嵌入方法包括HIN2Vec、Metapath2Vec等。这些方法会考虑节点和边的型信息,以及它们之间的关系,将它们嵌入到向量空间中,以便进行下一步的推荐计算。 4. 跨域推荐计算:利用嵌入后的节点向量进行跨域推荐计算。根据用户的行为和关系信息,计算用户与其他领域或域中物品的相似度,推荐相似度高的物品给用户。可以使用用户-物品相似度计算方法,例如余弦相似度或基于矩阵分解的方法,来计算用户与物品之间的关联程度。 5. 推荐结果生成:根据跨域推荐计算的结果,生成推荐列表或推荐排序。将相似度高的物品推荐给用户,以提供个性化的跨域推荐体验。 总结起来,基于异质图嵌入的跨域推荐主要包括数据准备、异质图构建、异质图嵌入、跨域推荐计算和推荐结果生成等步骤。通过构建合适的异质图结构,并利用异质图嵌入方法将节点和边嵌入到向量空间中,可以实现更准确和个性化的跨域推荐。 ### 回答3: 基于异质图嵌入的跨域推荐是一种利用图嵌入技术来实现不同领域或不同域之间的推荐系统。该方法通过将异质图中的不同节点和边分别表示为向量,然后通过学习节点和边的向量表示来计算节点之间的相似度,从而进行跨域推荐。 具体实现基于异质图嵌入的跨域推荐可以按照以下步骤进行: 1. 数据预处理:首先,需要对异质图中的不同节点和边进行编码,将其转化为数值表示。例如,可以使用独热编码来表示不同型的节点和边。 2. 构建异质图:根据不同领域或不同域的数据,可以构建一张异质图,其中不同型的节点表示不同的物品或用户,边表示不同的关系型。例如,在跨域音乐推荐中,可以将歌曲、用户、专辑等不同型的节点以及它们之间的关系用边连接起来。 3. 异质图嵌入:通过使用图嵌入技术,将图中的节点和边转化为低维度向量表示。常用的图嵌入算法包括DeepWalk、Node2Vec、LINE等。这些算法通过考虑节点的邻居信息来学习节点的向量表示,以保留节点之间的结构信息。 4. 跨域推荐计算:通过计算不同领域或不同域的节点之间的相似度,可以进行跨域推荐。一种常用的方法是通过计算节点之间的向量余弦相似度来度量它们的相似程度。根据节点之间的相似度,可以为用户推荐在其他领域中似的物品,或者为物品推荐似的用户。 5. 评估和优化:最后,需要对跨域推荐的性能进行评估,并进行优化。可以使用评估指标如准确率、召回率、覆盖率等来评估推荐结果的质量,并根据评估结果进行模型的调优和改进。 基于异质图嵌入的跨域推荐方法可以帮助解决不同领域或不同域之间的信息孤立问题,提高推荐系统的多样性和准确性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值