PAT Advanced 1076 Forwards on Weibo (30) [图的遍历,BFS,DFS]
题目
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]的更多相关文章
- 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 ...
- 1076. Forwards on Weibo (30) - 记录层的BFS改进
题目如下: Weibo is known as the Chinese version of Twitter. One user on Weibo may have many followers, a ...
- 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 ...
- PAT甲级1076. Forwards on Weibo
PAT甲级1076. Forwards on Weibo 题意: 微博被称为中文版的Twitter.微博上的一位用户可能会有很多关注者,也可能会跟随许多其他用户.因此,社会网络与追随者的关系形成.当用 ...
- 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 ...
- PAT (Advanced Level) 1076. Forwards on Weibo (30)
最短路. 每次询问的点当做起点,然后算一下点到其余点的最短路.然后统计一下最短路小于等于L的点有几个. #include<cstdio> #include<cstring> # ...
- 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 ...
- PAT甲题题解-1076. Forwards on Weibo (30)-BFS
题目大意:给出每个用户id关注的人,和转发最多的层数L,求一个id发了条微博最多会有多少个人转发,每个人只考虑转发一次.用BFS,同时每个节点要记录下所在的层数,由于只能转发一次,所以每个节点要用vi ...
- 【PAT甲级】1076 Forwards on Weibo (30 分)
题意: 输入两个正整数N和L(N<=1000,L<=6),接着输入N行数据每行包括它关注人数(<=100)和关注的人的序号,接着输入一行包含一个正整数K和K个序号.输出每次询问的人发 ...
随机推荐
- STM32学习笔记:IIC通信协议详解(附带软件模拟源码)
什么是IIC(I2C)? IIC 即Inter-Integrated Circuit(集成电路总线),这种总线类型是由飞利浦半导体公司设计出来的一种简单.双向.二线制.同步串行总线.它是一种多向控制总 ...
- Linux 内核 编译模块
背景: 由于调试内核或者由于分区大小限制,有时候内核组件不一定完全需要编进内核中. 所以,在开发中经常将内核组件编译成为模块,等到在恰当的时机加载. 概览: Linux内核模块的编译方法有两种: 1. ...
- Unity游戏开发面试基础知识
面试第一次知识总结: 一.Unity基本操作 1.unity提供哪几种光源? 点光源.平行光.聚光灯.区域光. 2.物体发生碰撞的必要条件什么? 两个物体必须有碰撞体Collider组件,一个物体上必 ...
- 云时代架构阅读笔记十五——之前碰到的Java面试题
1.一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制? 可以有多个类,但只能有一个public的类,并且public的类名必须与文件名相一致. 2.Java有 ...
- Java笔记--多线程
1.线程的创建与运行(方式一): --1)创建一个Thread的子类: --2)重写Thread类的run()方法: --3)创建一个子类的对象: --4)调用线程的start()方法来启动线程,Ja ...
- Day5 - C - Agri-Net POJ - 1258
Farmer John has been elected mayor of his town! One of his campaign promises was to bring internet c ...
- 图片上传--base64
<?php defined('BASEPATH') OR exit('No direct script access allowed'); include_once (APPPATH . &qu ...
- 利用python模拟鼠标点击自动完成工作,提升你的工作效率!
没有什么能比学以致用让学习变得更有动力的了. 不知道大家在工作中有没有一些工作需要重复的点击鼠标,因为会影响到财务统计报表的关系,我们每个月底月初都要修改ERP中的单据日期,单据多的时候光修改就能让你 ...
- nginx做维护页面
需求: 一个网站本来有好几个域名,然后也有好几个二级域名,现在停掉了,要求把所有的域名.二级域名,以及具体的文件请求,都指向一个维护页面. 1 单独在vhost里建一个conf文件 server { ...
- UVA - 10891 Game of Sum (区间dp)
题意:AB两人分别拿一列n个数字,只能从左端或右端拿,不能同时从两端拿,可拿一个或多个,问在两人尽可能多拿的情况下,A最多比B多拿多少. 分析: 1.枚举先手拿的分界线,要么从左端拿,要么从右端拿,比 ...
