1076 Forwards on Weibo (链接表层序遍历)

题意:给出关注列表,博主的粉丝会给博主点赞,粉丝的粉丝也会给博主点赞,一直递推到最多L层,求,最后会有多少人给博主点赞。

思路:将关注的粉丝用链接表存储,再对博主进行层序遍历,遍历L+1层(因为不能包含博主层),并且将遍历过的人都标记防止重复计算,同时算出所有遍历到的所有结点。结点数-1(不包含博主)即为答案。

(刚开始写了个深度为L+1的深度优先遍历,结果不对,因为深度遍历过的结点可能会与后面的兄弟结点重复,造成提前标记,故只能使用层序遍历)

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

vector<int>son[1010];
bool vis[1010];
int bfs(int u,int k){
    memset(vis,0,sizeof vis);
    queue<int>q;
    q.push(u);
    k++;
    int res=0;
    while(q.size()&&k--){
        int len=q.size();
        while(len--){
            int f=q.front();
            q.pop();
            if(vis[f])continue;//防止重复计算
            res++;
            vis[f]=1;
            for(auto x:son[f]){
                if(!vis[x]){
                    q.push(x);
                }
            }
        }
    }
    return res;
}
int main(){
    int n,k;
    cin>>n>>k;
    for(int i=1;i<=n;i++){
        int m;cin>>m;
        while(m--){
            int a;cin>>a;
            son[a].push_back(i);
        }
    }
    int q;cin>>q;
    while(q--){
        int a;cin>>a;
        cout<<bfs(a,k)-1<<endl;
    }
}
相关推荐
愣头不青2 分钟前
238.除了自身以外数组的乘积
数据结构·算法
人工智能AI酱28 分钟前
【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议
人工智能·python·算法·机器学习·ai·逻辑回归·正则化
WangLanguager30 分钟前
逻辑回归(Logistic Regression)的详细介绍及Python代码示例
python·算法·逻辑回归
m0_5180194832 分钟前
C++与机器学习框架
开发语言·c++·算法
一段佳话^cyx37 分钟前
详解逻辑回归(Logistic Regression):原理、推导、实现与实战
大数据·算法·机器学习·逻辑回归
qq_4176950538 分钟前
C++中的代理模式高级应用
开发语言·c++·算法
xiaoye-duck1 小时前
《算法题讲解指南:动态规划算法--路径问题》--5.不同路径,6.不同路径II
c++·算法·动态规划
ambition202421 小时前
最大子数组和算法全解析:从暴力枚举到动态规划优化
数据结构·c++·算法
没头脑的男大2 小时前
关于删除列表的那些事儿
算法
Book思议-2 小时前
【数据结构实战】线性表的应用
c语言·数据结构·算法·链表