首页 > 编程语言 >C++U7-07-图的遍历进阶

C++U7-07-图的遍历进阶

时间:2024-06-04 20:59:04浏览次数:14  
标签:遍历 07 int U7 ++ C++ vis maxn ve

学习目标

 引例

 深搜遍历

 

 

 

 

 

[【图的遍历进阶】有向图中的可达]

【算法分析】
从 a 点广搜,并用 vis 数组标记从 a 能够到达的点,如果 vis 
b
​
 =true,则表示能够到达,否则反之。

【参考代码】
#include<bits/stdc++.h>
using namespace std;
const int maxn = 2e5 + 9;
vector<int> ve[maxn];
bool vis[maxn];
int main() {
    int n, m, a, b;
    cin >> n >> m >> a >> b;
    for (int i = 0; i < m; i++) {
        int u, v;
        cin >> u >> v;
        ve[u].push_back(v);
    }
    queue<int> q;
    q.push(a);
    vis[a] = 1;
    while (q.size()) {
        int r = q.front();
        q.pop();
        for (int i = 0; i < ve[r].size(); i++) {
            int y = ve[r][i];
            if (!vis[y]) {
                vis[y] = 1;
                q.push(y);
            }
        }
    }
    if (vis[b]) cout << "Yes";
    else cout << "No";
    return 0;
}
View Code

 

 

 

广搜遍历

 

 

 

[【图的遍历进阶】朋友圈的数量]

 

【算法分析】
其实就是求图中连通块的数量,可以使用广搜或者深搜。每次从没有访问过的点开始搜索,将能够到达的点全部标记。

【参考代码】
#include<bits/stdc++.h>
using namespace std;
const int maxn = 2e5 + 9;
vector<int> ve[maxn];
bool vis[maxn];
void dfs(int x) {
    vis[x] = 1;
    for (int i = 0; i < ve[x].size(); i++) {
        int y = ve[x][i];
        if (vis[y]) continue;
        dfs(y);
    }
}
int main() {
    int n, m;
    cin >> n >> m;
    for (int i = 0; i < m; i++) {
        int u, v;
        cin >> u >> v;
        ve[u].push_back(v);
        ve[v].push_back(u);
    }
    int ans = 0;
    for (int i = 1; i <= n; i++) {
        if (!vis[i]) {
            dfs(i);
            ans++;
        }
    }
    cout << ans;
    return 0;
}
View Code

 

[【图的遍历进阶】图的遍历]

 

【算法分析】
如果从每个点开始搜索去找到编号最大的点,这样做会超时。如果一些点组成的集合 S ,能够到达最大的编号的点是相同的,那么如果建反边,那么从这个编号最大点必定能够到达集合 S 的所有点。因此可以从大到小枚举点的编号 i,当一个点没有被访问过,就从该点开始搜索所有它能到达的点,那么这些点能够到达的最大编号一定是 i。

【参考代码】
#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5 + 9;
vector<int> ve[maxn];
int ans[maxn], vis[maxn];
void dfs(int x, int ma) {
    vis[x] = 1;
    ans[x] = ma;
    for (int i = 0; i < ve[x].size(); i++) {
        int y = ve[x][i];
        if (vis[y]) continue;
        dfs(y, ma);
    }
}
int main() {
    int n, m;
    cin >> n >> m;
    for (int i = 0; i < m; i++) {
        int u, v;
        cin >> u >> v;
        ve[v].push_back(u);
    }
    for (int i = n; i >= 1; i--) {
        if (!vis[i]) dfs(i, i);
    }
    for (int i = 1; i <= n; i++) {
        cout << ans[i] << " ";
    }
    return 0;
}
View Code

 

 

本节课作业讲解分析

链接:https://pan.baidu.com/s/1TjhdjO84yjwQ5-UNvrrThw?pwd=0000
提取码:0000

 

标签:遍历,07,int,U7,++,C++,vis,maxn,ve
From: https://www.cnblogs.com/jayxuan/p/18231674

相关文章

  • IAR+GD32E507芯片工程环境常见问题
    本工程是原有产品已创建成功的工程,仅需导入、配置相关环境采用芯片:GD32E507ZE常见工程导入步骤1、安装IAR2、导入工程3、编译及报错解决1).h头文件目录未包含报错现象:提示部分头文件找不到解决:如下图所示,注意最好添加相对路径,便于使用。2)未选择CPU报错现象:解决:添加......
  • 【每周例题】C++ 力扣 旋转字符串
    旋转字符串 题目旋转字符串 题目分析方法1:模拟字符串1.采用双for循环去模拟字符串旋转,第一个for循环,模拟字符串循环位移;第二个for循环,进行逐个字符串检测2.使用if进行判断是否符合要求方法2:假设我们将goal字符串拆分为2个字符串,将其命名为R、L,我们将会得到以下式子go......
  • 快速入门C++正则表达式
    正则表达式(RegularExpression,简称Regex)是一种强大的文本处理工具,广泛用于字符串的搜索、替换、分析等操作。它基于一种表达式语言,使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。正则表达式不仅在各种编程和脚本语言中被广泛支持,还是很多文本编辑器和处理工......
  • STM32F407 hal库FFT
    简介:本文所用开发板为立创天空星,主控芯片为STM32F407VET6,F407系列应该都能使用本文的方法。也推荐大家可以买一块立创天空星玩玩,很好用。1.设置调试模式为SWD调试2.将低速和高速时钟设置为外部时钟源3.时钟设置(按下图即可)4.设置ADC,可以和中断部分一起看注意DMA设定时......
  • C++知识点
    explicit关键字explicit关键字explicit关键字在理解explicit关键字之前,我们必须要了解构造函数的类型转换作用,以便于我们更好的理解explicit关键字,如果有不懂构造函数,可以来看看这篇文章:构造函数点击查看代码classDate{public://构造函数Date(intyear):_......
  • 华为OD机试2024年最新题库(Python、JAVA、C、C++合集)C卷+D卷
    介绍博主介绍:CSDN领军人物top1的作者,全网粉丝30w+,文章累计被阅读3800w+,直接帮助200+,间接帮助800+同学进入od添加或私信博主免费获取本题解析以及代码24年5月份开始,考的都是OD统一考试(D卷),题库已经整理好了,命中率95%以上。5-10月份考的都是D卷真题,都是原题,圈内有多种......
  • C++ 强制类型转换运算符简介
    C++提供了四种强制类型转换运算符:static_cast、reinterpret_cast、const_cast和dynamic_cast。这些运算符各自具有特定的用途,适用于不同的类型转换需求。本文将详细介绍这四种运算符及其应用场景,并讨论它们在向上转换中的使用方法。1.static_caststatic_cast用于在编译时执......
  • C++ Builder 2010 绘制坐标
     一、步骤:1.先确定Image的位置,大小(可以不写)          2.设置初始面板,绘制初始的x,y坐标轴          3.画x,y向的刻度线,标刻x,y轴刻度          4.获取数据(可以不写)          5.将数......
  • 如何选择实名认证接口?C++身份证二、三要素实名认证接口提供厂商
    线上平台进行身份证实名认证,有助于保障交易的安全性,防止身份信息被盗用的风险,其主要应用于金融、在线银行、支付平台、社交媒体、账号注册、内容发布等多种应用场景。那么,又当如何选择实名认证接口厂家呢?翔云人工智能开放平台专注于API接口的提供,为有需要的企业提供了便......
  • C++发票查验真假的接口厂家有哪些?数电票、医疗票据查验
    现如今,随着数字化应用的不断普及,财务工作也在不断的由人工向数字化转型。企业财务进行数字化转型,能够推动财务管理职能的转型升级,通过运用云计算、大数据等技术,重构财务组合和业务流程,实现业财融合,提升会计信息质量、工作效率、合规程度及价值创造能力。翔云人工智能开放......