题目

Weibo is known as the Chinese version of Twitter. One user on Weibo may have many followers, and may follow many other users as well. Hence a social network is formed with followers relations. When a user makes a post on Weibo, all his/her followers can view and forward his/her post, which can then be forwarded again by their followers. Now given a social network, you are supposed to calculate the maximum potential amount of forwards for any specific user, assuming that only L levels of indirect followers are counted.

Input Specification:

Each input file contains one test case. For each case, the first line contains 2 positive integers: N (<=1000), the number of users; and L (<=6), the number of levels of indirect followers that are counted. Hence it is assumed that all the users are numbered from 1 to N. Then N lines follow, each in the format:

M[i] user_list[i]

where M[i] (<=100) is the total number of people that user[i] follows; and user_list[i] is a list of the M[i] users that are followed by user[i]. It is guaranteed that no one can follow oneself. All the numbers are separated by a space. Then finally a positive K is given, followed by K UserID’s for query.

Output Specification:

For each UserID, you are supposed to print in one line the maximum potential amount of forwards this user can triger, assuming that everyone who can view the initial post will forward it once, and that only L levels of indirect followers are counted.

Sample Input:

7 3

3 2 3 4

0

2 5 6

2 3 1

2 3 4

1 4

1 5

2 2 6

Sample Output:

4

5

题目分析

用户发一条微博后,其粉丝进行一次转发,其粉丝的粉丝进行一次转发,已知所有人关系网图,求最大转发数,间接粉丝层数<=L(但是从样例分析和答案来看,是间接粉丝层数<=L-1,暂时不明白怎么从题目分析出L-1)

解题思路

思路 01(BFS 最优)

广度优先搜索,定义顶点结构体,在顶点中定义属性level记录该节点访问层级,超过L后停止访问

思路 02 (DFS)

深度优先搜索,使用参数depth递归记录层级,超过L后停止访问

问题:DFS中访问过的节点标记为已访问,会丢失一些路径,样例中假设没有6-3-5-7路径,访问6-3-1-4后,再访问6-3-4-5时,因为4标记已访问,所以这条路径不可访问,节点5将不会被统计

解决办法:用数组记录节点被访问时的层级,若再次被访问时,看当前层级是否小于level数组中之前被访问层级,若小于可以访问

Code

Code 01(BFS 最优)

#include <iostream>
#include <vector>
#include <queue>
using namespace std;
const int maxn=1010;
vector<int> g[maxn]; //粉丝列表
int L;
struct node {
int v;
int layer;
// node () {}
// node(int _v):v(_v) {}
} ;
int bfs(int v) {
int cnt=0;
queue<node> q;
q.push({v,0});
int vis[maxn]= {0};
vis[v]=1;
while(!q.empty()) {
node now = q.front();
q.pop();
for(int i=0; i<g[now.v].size(); i++) {
if(now.layer<L&&vis[g[now.v][i]]==0) {
q.push({g[now.v][i],now.layer+1});
cnt++;
vis[g[now.v][i]]=1;
}
}
}
return cnt;
}
int main(int argc,char * argv[]) {
int n,m,z,t,y;
scanf("%d %d",&n,&L);
for(int i=1; i<=n; i++) {
scanf("%d",&m);
for(int j=0; j<m; j++) {
scanf("%d",&z);
g[z].push_back(i);
}
}
scanf("%d",&t);//查询次数
for(int i=0; i<t; i++) {
scanf("%d",&y);
printf("%d\n",bfs(y));//广度搜素
} return 0;
}

Code 02(DFS)

#include <iostream>
#include <vector>
#include <queue>
using namespace std;
const int maxn=1010;
vector<int> g[maxn]; //粉丝列表
int L,vis[maxn],level[maxn];
void dfs(int v, int depth) {
if(depth>L)return;
vis[v]=1;
level[v]=depth;
for(int i=0; i<g[v].size(); i++) {
if(vis[g[v][i]]!=1||depth+1<level[g[v][i]])
dfs(g[v][i],depth+1);
}
}
int main(int argc,char * argv[]) {
int n,m,z,t,y;
scanf("%d %d",&n,&L);
for(int i=1; i<=n; i++) {
scanf("%d",&m);
for(int j=0; j<m; j++) {
scanf("%d",&z);
g[z].push_back(i);
}
}
scanf("%d",&t);//查询次数
for(int i=0; i<t; i++) {
scanf("%d",&y);
fill(vis,vis+maxn,0);
int cnt=0;
dfs(y,0);//深度搜素
for(int j=1; j<=n; j++) {
if(vis[j]==1)cnt++;
}
printf("%d\n",cnt-1);
} return 0;
}

PAT Advanced 1076 Forwards on Weibo (30) [图的遍历,BFS,DFS]的更多相关文章

  1. PAT 甲级 1076 Forwards on Weibo (30分)(bfs较简单)

    1076 Forwards on Weibo (30分)   Weibo is known as the Chinese version of Twitter. One user on Weibo m ...

  2. 1076. Forwards on Weibo (30) - 记录层的BFS改进

    题目如下: Weibo is known as the Chinese version of Twitter. One user on Weibo may have many followers, a ...

  3. 1076. Forwards on Weibo (30)【树+搜索】——PAT (Advanced Level) Practise

    题目信息 1076. Forwards on Weibo (30) 时间限制3000 ms 内存限制65536 kB 代码长度限制16000 B Weibo is known as the Chine ...

  4. PAT甲级1076. Forwards on Weibo

    PAT甲级1076. Forwards on Weibo 题意: 微博被称为中文版的Twitter.微博上的一位用户可能会有很多关注者,也可能会跟随许多其他用户.因此,社会网络与追随者的关系形成.当用 ...

  5. PAT Advanced 1013 Battle Over Cities (25) [图的遍历,统计连通分量的个数,DFS,BFS,并查集]

    题目 It is vitally important to have all the cities connected by highways in a war. If a city is occup ...

  6. PAT (Advanced Level) 1076. Forwards on Weibo (30)

    最短路. 每次询问的点当做起点,然后算一下点到其余点的最短路.然后统计一下最短路小于等于L的点有几个. #include<cstdio> #include<cstring> # ...

  7. PAT 1076. Forwards on Weibo (30)

    Weibo is known as the Chinese version of Twitter. One user on Weibo may have many followers, and may ...

  8. PAT甲题题解-1076. Forwards on Weibo (30)-BFS

    题目大意:给出每个用户id关注的人,和转发最多的层数L,求一个id发了条微博最多会有多少个人转发,每个人只考虑转发一次.用BFS,同时每个节点要记录下所在的层数,由于只能转发一次,所以每个节点要用vi ...

  9. 【PAT甲级】1076 Forwards on Weibo (30 分)

    题意: 输入两个正整数N和L(N<=1000,L<=6),接着输入N行数据每行包括它关注人数(<=100)和关注的人的序号,接着输入一行包含一个正整数K和K个序号.输出每次询问的人发 ...

随机推荐

  1. ffmpeg 学习:002-代码架构

    前言 使用 ffmpeg 库时,最好先理解好ffmpeg的代码结构图. 下面这张图表明了FFmpeg在解码一个视频的时候的函数调用流程,为了保证结构清晰,其中仅列出了最关键的函数,剔除了其它不是特别重 ...

  2. CVE-2019-0708 漏洞分析及相关测试

    在CVE-2019-0708公布后几天就已经尝试过复现该漏洞,但借助当时exp并没能成功复现反弹shell的过程遂放弃,故借助这次漏洞复现报告再来尝试复现该漏洞,因为还在大三学习中,有很多知识还没有掌 ...

  3. prepareBeanFactory方法源码跟踪

    看这篇文章之前可以先了解之前的跟踪流程,https://www.jianshu.com/p/4934233f0ead 代码过宽,可以shift + 鼠标滚轮 左右滑动查看 AbstractApplic ...

  4. 接口补偿机制需求分析&方案设计

    接口补偿机制需求分析&方案设计文章目录接口补偿机制需求分析&方案设计需求分析背景解决方案业务示例注意事项示例业务Controller实现重试信息类&数据处理入库接口重试的主要方 ...

  5. Python中pandas透视表pivot_table功能详解(非常简单易懂)

    一文看懂pandas的透视表pivot_table 一.概述 1.1 什么是透视表? 透视表是一种可以对数据动态排布并且分类汇总的表格格式.或许大多数人都在Excel使用过数据透视表,也体会到它的强大 ...

  6. JuJu团队11月30号工作汇报

    JuJu团队11月30号工作汇报 JuJu   Scrum 团队成员 今日工作 剩余任务 困难 于达  提供类似generator的数据产生接口  改进代码  对julia不够熟悉 婷婷  和队友一起 ...

  7. tools.eclipse.内存配置

    环境:jdk1.7+eclipse luna 选择:Run ->Run Configurations, 在弹出框右侧中选择Arguments, 在VM arguments最后加入 -Xms256 ...

  8. [LeetCode] 929. Unique Email Addresses 独特的邮件地址

    Every email consists of a local name and a domain name, separated by the @ sign. For example, in ali ...

  9. 023-PHP常用数组函数

    <?php $colors = array("red", "green", "blue","yellow"); p ...

  10. zerone 01串博弈问题

    近日领到了老师的期末作业 其中有这道 01 串博弈问题: 刚开始读题我也是云里雾里 但是精读数遍 “细品” 之后,我发现这是一个 “动态规划” 问题.好嘞,硬着头皮上吧. 分析问题:可知对每个人有两手 ...