【东华大学oj】链表组件

链表组件

时间限制: 1s

类别: DS:数组与链表->链表--较难

问题描述

给定链表头结点 head,该链表上的每个结点都有一个唯一的整型值 。

同时给定列表 G,该列表是上述链表中整型值的一个子集。

返回列表 G 中组件的个数,这里对组件的定义为:链表中一段极长连续结点的值(该值必须在列表 G 中)构成的集合。极长的含义是:这段连续结点的前面或后面结点不属于G。

示例 1:

输入: 

head: 0->1->2->3

G = [0, 1, 3]

输出: 2

解释: 

链表中,0 和 1 是相连接的,且 G 中不包含 2,所以 [0, 1] 是 G 的一个组件,同理 [3] 也是一个组件,故返回 2。

示例 2:

输入: 

head: 0->1->2->3->4

G = [0, 3, 1, 4]

输出: 2

解释: 

链表中,0 和 1 是相连接的,3 和 4 是相连接的,所以 [0, 1] 和 [3, 4] 是两个组件,故返回 2。

输入说明

首先输入链表长度len,然后输入len个整数,以空格分隔。

再输入G的大小m,然后输入m个整数,以空格分隔。

输出说明

输出一个整数,表示结果。

#include<iostream>
#include<algorithm>
#include<vector>
#include <unordered_set>

using namespace std;



struct ListNode

{

    int val;

    ListNode *next;

    ListNode() : val(0), next(NULL) {}

    ListNode(int x) : val(x), next(NULL) {}

    ListNode(int x, ListNode *next) : val(x), next(next) {}

};

class Solution
{

public:
    int numComponents(ListNode* head, vector<int>& G)
    {

        ListNode*p=head;
        unordered_set<int> Gset(G.begin(),G.end());
        int k=0;
        bool found=0;
        int len=0;
        while(p!=nullptr)
        {
            if(Gset.find(p->val)!=Gset.end())
            {
                if(!found)
                {
                    found=1;
                }
            }
            else
            {
                if(found)
                {
                    found=0;
                    len++;
                }
            }
            p=p->next;

        }

        if(found)
        {
            len++;
        }
        return len;
    }

};

ListNode *createByTail()

{

    ListNode *head;

    ListNode *p1,*p2;

    int n=0,num;

    int len;

    cin>>len;

    head=NULL;

    while(n<len && cin>>num)

    {

        p1=new ListNode(num);

        n=n+1;

        if(n==1)

            head=p1;

        else

            p2->next=p1;

        p2=p1;

    }

    return head;

}

int main()

{

    vector<int> G;

    int m,data,res;

    ListNode* head = createByTail();

    cin>>m;

    for(int i=0; i<m; i++)

    {

        cin>>data;

        G.push_back(data);

    }

    res=Solution().numComponents(head,G);

    cout<<res<<endl;

    return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Juneeeeeeeeeeeee

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值