首页 > 其他分享 >图中点的层次

图中点的层次

时间:2023-03-24 09:44:05浏览次数:32  
标签:层次 int scanf d% ne push include 图中点

https://www.acwing.com/problem/content/849/

本题为经典的图形插入遍历题目

首先是手写链表 实现

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <queue>

using namespace std;

const int N = 100010;

int n, m;
int h[N], e[N], ne[N], idx;
int d[N];// 保存1号点到各个点的距离

void add(int a, int b)
{
    e[idx] = b, ne[idx] = h[a], h[a] = idx ++ ;
}

int bfs()
{
    memset(d, -1, sizeof d);

    queue<int> q;
    d[1] = 0;
    q.push(1);

    while (q.size())
    {
        int t = q.front();
        q.pop();
        // 循环遍历所有与t相距为1的节点
        for (int i = h[t]; i != -1; i = ne[i]) // ne[i]上的点都是与i节点距离为1的点
        {
            int j = e[i]; // 向外走一步
            if (d[j] == -1) // 如果j没有被遍历过
            {
                d[j] = d[t] + 1; // 因为路径长度都是1,所以直接在上一步的基础上加上1即可
                q.push(j); // 将j加到队列中
            }
        }
    }
    return d[n]; // 返回的d[n]即是节点1到节点n的距离

    
}


int main()
{
    scanf("%d%d", &n, &m);
    memset(h, -1, sizeof h);

    for (int i = 0; i < m; i ++ )
    {
        int a, b;
        scanf("%d%d", &a, &b);
        add(a, b);
    }

    cout << bfs() << endl;

    return 0;
}

但本人还是喜欢用stl,虽然慢,vector

#include <bits/stdc++.h>
using namespace std;

const int N = 1e5 + 10;

int n, m;
vector<int> h[N];
int d[N];

int bfs()
{
    memset(d, -1, sizeof d);

    queue<int> q;
    q.push(1);
    d[1] = 0;
    while (q.size())
    {
        int t = q.front();
        q.pop();

        for (auto i: h[t])
        {
            if (d[i] == -1)
            {
                d[i] = d[t] + 1;
                q.push(i);
            }
        }
    }

    return d[n];
}

int main()
{
    scanf ("%d%d", &n, &m);

    for (int i = 0; i < m; i ++ )
    {
        int a, b;
        scanf ("%d%d", &a, &b);
        h[a].push_back(b);
    }

    cout << bfs() << endl;

    return 0;
}

 

标签:层次,int,scanf,d%,ne,push,include,图中点
From: https://www.cnblogs.com/ljq2022/p/17250339.html

相关文章

  • R语言用贝叶斯层次模型进行空间数据分析|附代码数据
    阅读全文:http://tecdat.cn/?p=10932最近我们被客户要求撰写关于贝叶斯层次模型的研究报告,包括一些图形和统计输出。在本文中,我将重点介绍使用集成嵌套拉普拉斯近似方法......
  • TZOJ 1222: 数据结构练习题――先序遍历二叉树 层次遍历
    描述 给定一颗二叉树,要求输出二叉树的深度以及先序遍历二叉树得到的序列。本题假设二叉树的结点数不超过1000。 输入 输入数据分为多组,第一行是测试数据的组数......
  • 容量管理的三个层次
    ITIL把容量管理分为三个层次:业务层(BusinessLevel)、服务层(ServiceLevel)和组件层(ComponentLevel)。这三个层次的流程中有许多类似的活动,但是每个子流程有不同的侧重点。业务......
  • 层次聚类算法
    动动发财的小手,点个赞吧!层次聚类是一种构建聚类层次结构的聚类算法。该算法从分配给它们自己的集群的所有数据点开始。然后将两个最近的集群合并到同一个集群中。最后,当......
  • 系统评价——层次分析AHP法R语言实践(四)
    对一个事物的评价往往会涉及多个因素或者多个指标,评价是在多个因素相互作用下的一个综合判断。多指标综合评价方法具有以下的特点:包含若干个指标,分别说明被评价对象的不同......
  • 层次选择器
    <doctypehtml><html><head>  <metacharset="utf-8">  <title>study</title>  <linkrel="stylesheet"href="study.css"type="text/css">  <sty......
  • 28.层次查询
    遍历树自底到顶hr@ORCLPDB012023-02-2620:31:01>selectemployee_id,last_name,job_id,manager_id2fromemployees3startwithemployee_id=1014conn......
  • 4.1- 存储系统层次结构
    基本存储体系原理:包括:存储程序(存储设备),程序控制(CPU)1.输入输出设备将程序与数据写入主存2.CPU取指令3.CPU执行指令期间读取数据4.CPU写回运算结果5.输出设备输出......
  • R语言k-means聚类、层次聚类、主成分(PCA)降维及可视化分析鸢尾花iris数据集|附代码数据
    原文链接:http://tecdat.cn/?p=22838最近我们被客户要求撰写关于鸢尾花iris数据集的研究报告,包括一些图形和统计输出。本练习问题包括:使用R中的鸢尾花数据集 (a)部分:k-......
  • 数据分享|R语言分析上海空气质量指数数据:kmean聚类、层次聚类、时间序列分析:arima模型
    全文链接:http://tecdat.cn/?p=30131最近我们被客户要求撰写关于空气质量指数的研究报告,包括一些图形和统计输出。最近我们被客户要求撰写关于上海空气质量指数的研究报告......