PAT (Advanced Level) Practise 1076 Forwards on Weibo (30)
来源:互联网 发布:webshell powershell 编辑:程序博客网 时间:2024/05/18 16:37
1076. Forwards on Weibo (30)
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 33 2 3 402 5 62 3 12 3 41 41 52 2 6Sample Output:
45
题意:给出微博用户的关注情况,在假定某一用户的粉丝看到某条微博一定会转发的情况下,求可能被转发的次数
解题思路:bfs
#include <iostream>#include <cstdio>#include <cstring>#include <string>#include <algorithm>#include <queue>#include <stack>#include <cmath>#include <map>#include <bitset>#include <set>#include <vector>#include <functional>using namespace std;#define LL long longconst int INF = 0x3f3f3f3f;int n, k,a,b,q;int s[1005],nt[100009],e[100009],dis[1005];int main(){ while(~scanf("%d%d",&n,&k)) { int cnt=1; memset(s,-1,sizeof s); for(int i=1;i<=n;i++) { scanf("%d",&a); for(int j=1;j<=a;j++) { scanf("%d",&b); nt[cnt]=s[b],s[b]=cnt,e[cnt++]=i; } } scanf("%d",&q); while(q--) { scanf("%d",&a); memset(dis,INF,sizeof dis); dis[a]=0; int ans=0; queue<int>q; q.push(a); while(!q.empty()) { int pre=q.front(); q.pop(); if(dis[pre]<=k) ans++; else break; for(int i=s[pre];~i;i=nt[i]) { if(dis[e[i]]>dis[pre]+1) { dis[e[i]]=dis[pre]+1; q.push(e[i]); } } } printf("%d\n",ans-1); } } return 0;}
- PAT (Advanced Level) Practise 1076 Forwards on Weibo (30)
- PAT (Advanced Level) Practise 1076 Forwards on Weibo (30)
- 1076. Forwards on Weibo (30)【树+搜索】——PAT (Advanced Level) Practise
- Pat(Advanced Level)Practice--1076(Forwards on Weibo)
- PAT Advanced Level 1076. Forwards on Weibo (30)
- 【PAT】【Advanced Level】1076. Forwards on Weibo (30)
- PAT (Advanced) 1076. Forwards on Weibo (30)
- PAT (Advanced Level) 1076. Forwards on Weibo (30) 微博转发 BFS
- PAT 1076-Forwards on Weibo (30)
- PAT-Forwards on Weibo
- PAT 1076 Forwards on Weibo BFS
- PAT A 1076. Forwards on Weibo (30)
- PAT-1076. Forwards on Weibo (30)
- pat 1076. Forwards on Weibo (30)
- PAT 1076. Forwards on Weibo (30)
- PAT 1076. Forwards on Weibo (30)
- PAT 1076. Forwards on Weibo (30)
- 【PAT】 1076. Forwards on Weibo (30)
- hibernate笔记05 Hibernate实现类的crud(增删改查)操作
- sys.exit(n)和exit()、os._exit(n)
- 建立一个场景图形
- GDOI2017总结~酱油记
- 获得http://ip:8080的方法
- PAT (Advanced Level) Practise 1076 Forwards on Weibo (30)
- 打包含有多个main程序的jar包运行方式
- MFC改变鼠标指针
- 构造函数统计创建的对象个数
- Acache工具类
- 【乱搞】正则表达式
- 百度地图海亮点解决打点多的卡顿问题
- 推荐一款ssh应用(Termius):手机上远程登录服务器,手机上ssh客户端
- 51nod 1705 七星剑