1076 Forwards on Weibo (30)(30 分)

注意计算层数的时候不是在pop之后,因为起始点不能算,所以在for里面计算

//邻接矩阵
#include<iostream>
#include<cstring>
#include<queue>
using namespace std;
const int maxv = 1e3 + 10;
struct node {
    int v, layer;
};
int G[maxv][maxv];
bool inq[maxv];
int n, l;
int BFS(int v)
{
    int ans = 0;
    node start;
    start.v = v;
    start.layer = 0;
    queue<node>q;
    q.push(start);
    inq[start.v] = true;
    while (!q.empty())
    {
        node topNode = q.front();
        q.pop();
        int u = topNode.v;
        for (int i = 1; i <= n; i++)
        {
            node next;
            next.layer = topNode.layer + 1;
            if (G[u][i]&&inq[i]==false)
            {
                next.v = i;
                q.push(next);
                inq[i] = true;
                if (next.layer <= l)ans++;
            }
        }
    }
    return ans;
}

int main()
{
    scanf("%d%d", &n, &l);
    for (int i = 1; i <= n; i++)
    {
        int m, u;
        scanf("%d", &m);
        while (m--)
        {
            scanf("%d", &u);
            G[u][i] = 1;
        }
    }
    int k;
    scanf("%d", &k);
    while (k--)
    {
        int query;
        memset(inq, false, sizeof(inq));
        scanf("%d", &query);
        int ans=BFS(query);
        printf("%d\n", ans);
    }
    return 0;
}

邻接表写法

int BFS(int v)
{
    int ans = 0;
    queue<node>q;
    node start;
    start.v = v;
    start.layer = 0;
    q.push(start);
    inq[start.v] = true;
    while (!q.empty())
    {
        node topNode = q.front();
        q.pop();
        int u = topNode.v;
        for (int i = 0; i < Adj[u].size(); i++)
        {
            node next;
            next.v = Adj[u][i];
            next.layer = topNode.layer + 1;
            if (!inq[next.v] && next.layer <= l)
            {
                ans++;
                q.push(next);
                inq[next.v] = true;
            }
        }
    }
    return ans;
}
···
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AI阅读 16,053评论 3 119
  • 需求思路 读取时候可以并发进行,读取后要返回读取状态。 写入文件时候不可以读取,并且文件写入时不可以并发的进行写入...
    哈尔湖阅读 4,816评论 0 0
  • 很多时候我们并不首要关注库本身的实现,或者根本无法看到其底层逻辑,但又必须确认某些函数或变量的命名(如排查定义冲突...
    团不慌阅读 25,426评论 0 6

友情链接更多精彩内容