当前位置: 首页 > article >正文

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

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

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

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

#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;
    }
}


http://www.kler.cn/a/153990.html

相关文章:

  • 实现了两种不同的图像处理和物体检测方法
  • 【vmware+ubuntu16.04】vm虚拟机及镜像安装-tools安装包弹不出来问题
  • EEG+EMG学习系列 (1) :一个基于小波的自动睡眠评分模型
  • PhpSpreadsheet导出图片
  • 计算机网络-理论部分(二):应用层
  • delphi fmx android 离线人脸识别
  • Linux常用命令汇总
  • 【python】python列表的用法记录
  • 第15关 K8s HPA:自动水平伸缩Pod,实现弹性扩展和资源优化
  • 玄学调参实践篇 | 深度学习模型 + 预训练模型 + 大模型LLM
  • java学习part26线程安全
  • Maven终端打包时报Unknown lifecycle phase “.test.skip=true“
  • Java Servlet
  • MySQL安全相关——TDE和数据脱敏功能介绍
  • C++的类和对象(一)
  • 分享88个节日PPT,总有一款适合您
  • 【slab/0x40 UAF】TPCTF2023 - core 一题多解
  • 微信小程序实现打分效果代码整理
  • Golang分布式事务
  • 尝试修改vim光标的思路
  • 文件搜索工具HoudahSpot mac中文版特点
  • 网站更换IP的四大注意事项
  • MagicPipe3D地下管网三维建模数据规格
  • 医疗器械设备模组的具体应用
  • UniApp项目中 使用微信小程序原生语言 进行开发
  • 如何在vs2017及以前版本(vs2010、vs2015)上添加 添加类型库中的MFC类