例题_树基础 P5318

news/2025/1/18 23:15:06/文章来源:https://www.cnblogs.com/yhy2013/p/18679020

洛谷P5318

分析

关键词

  • n篇文章
  • m条参考文献引用关系
  • x文章有y参考文献
  • BFS&&DFS结果

步骤

  1. 定义 不仅要定义关键词,还要再定义一个容器 这里用\(set\)
set<int>e[100009];

注意要初始化

  1. 输入 输入n m x y这几个关键字

  2. 计算过程 分两步

  • 深搜
  • 广搜
  1. 输出 先调用函数,在输出结果

代码

伪代码

定义数组,同时定义 n m x y
void init(){输入初始化
}
void dfs(){标记走过 输出标记
}
void bfs(){定义队列初始化while(){判断输出标记}
}
int main(){init();dfs();putcharmemsetbfs();putcharreturn 0;
}

\(Code\)

#include<bits/stdc++.h>
using namespace std;
int n,m;
set<int>e[100009];
bool vis[100009];
void init(){for(scanf("%d%d",&n,&m);m;--m){int u=0,v=0;scanf("%d%d",&u,&v);e[u].insert(v);}
}
void dfs(int x=1){if(vis[x])return;vis[x]=1;printf("%d ",x);for(int v:e[x])dfs(v);
}
void bfs(){queue<int>q;q.push(1);while(!q.empty()){int x=q.front();q.pop();if(vis[x])continue;vis[x]=1;printf("%d ",x);for(int v:e[x])q.push(v);}
}
int main(){init();dfs();putchar('\n');memset(vis,0,sizeof(vis));bfs();putchar('\n');return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/871491.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

集合框架

集合框架:Collection集合、集合存储对象的原理等学习视频 集合的概述public class Demo01 {public static void main(String[] args) {//简单确认一下Collection集合特点ArrayList<String> list = new ArrayList<>();list.add("java1");list.add("…

uniapp获取元素高度不准确问题解决

uniapp通过boundingClientRect获取的元素高度和实际高度差了不少,下面是复现和解决过程: 我的代码: 得到的结果: 高度只有105 用工具量一下: 实际有240px,遂gpt问下: 注意到了缩放比这个之前没想到的点,往下面看gpt更多的回复内容: 先获取系统缩放比,再乘以拿到的高度…

嵌入式Linux驱动开发学习--韦东山老师嵌入式Linux学习

最无益,只怕一日曝十日寒,贵在有恒。 目录2025-01-181、基础内容2、通用GPIO操作3、硬件操作4、驱动涉及的思想_面向对象_分层_分离1)面向对象2)分层3)分离5、驱动进化之路_总线设备驱动模型6、驱动进化之路_设备树的语法7、驱动进化之路_内核对设备树的处理与使用2025-01…

zabbix监控网络设备流量

项目环境一台liunx服务器,这里使用的为ubuntu22.04(192.168.86.140) 一台华为交换机,本次监控的就是该交换机的端口流量(192.168.86.20) 一台pc主机,使用该主机模拟流量变化ENSP拓扑图:安装zabbix 这里使用shell脚本进行安装,仅为ubuntu22.04的安装方式,别的版本可以参看…

关于动态规划

主要问题大概是动规基础(斐波那契),背包,打家劫舍,股票,子序列。 解决也主要是先分类,建立dp数组,明确dp数组的含义,dp数组的初始化,遍历顺序。 动规基础斐波那契数列,爬楼梯,建立dp数组的时候,递推公式的推导就要参考建立dp数组并且明确dp数组的含义 比如下面的最…

强力工具助你一臂之力:XXECheck–全面提升XML安全,防护XXE漏洞!

泷羽Sec-trackXXECheck XXECheck 是一种用于检测和防止 XML 外部实体 (XXE) 注入攻击的安全工具或库,一款XXE漏洞检测工具,支持 DoS 检测(DoS 检测默认开启)和 DNSLOG 两种检测方式,能对普通 xml 请求和 xlsx 文件上传进行 XXE 漏洞检测。 源地址:https://github.com/Wei…

知乐

儒家理想境界追求心灵的安顿过程 孔颜之乐 曾点之乐 潘立勇教授在[宋明理学休闲审美哲学的内在张力]中的一段描述:[1]宁新昌.孔颜之乐与曾点气象——兼论儒家的自由境界[C]//中华炎黄文化研究会,广东炎黄文化研究会,暨南大学.“21世纪中华文化世界论坛”第五次国际学术研讨…

[ABC283E] Don‘t Isolate Elements

题目:思路: 很明显总的情况是2^h*w种,然后不难发现改变一行只会影响到相邻两行,也就是说前面的决策不会影响到后面的决策,只有当前面的决策全部合理才能走后一步。 所以取dp:dp[i][j][k]为前i行,j(当前行是1/0否改变),k(当前行的前一行是1/0否改变)。 所以有递推式:dp[i][j]…

在 nuget 私服 BaGet 中应用https 以及 gitea action runner 自动打包

最近赋闲,想起之前工作中代码管理的一点经历,就是在打包项目的时候,类库的版本号几乎没变过,一个项目运行多少年了,版本号还是1.0.0。😂 即使用到了 nuget 私服,基本上也是手动打包的,CI 工具基本都是用到 api 项目。于是想结合 gitea 的 CI 工具 act runner 试用一下…

记录一下双多控开关接法

实际上双控就是单刀双掷开关,多控就是双刀双掷开关。多控里L1A+L1B是输入的俩个接上级出来的俩根线,LA和LB是反着的接上总有一路能通。输入俩通道输出俩通道所以可以无限串联。实际上双控就是单刀双掷开关,多控就是双刀双掷开关。 多控里L1A+L1B是输入的俩个接上级出来的俩根…

Day 7

1月17日,继续看了一些SpringBoot视频, SpringBoot的实现步骤SpringBoot项目的起步依赖 <!-- springboot工程需要继承的父工程 --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifac…

如果通过 vxe-table 实现 Excel,可以和 Excel、WPS 复制粘贴

如果通过 vxe-table 实现 Excel,可以和 Excel、WPS 复制粘贴 官网:https://vxetable.cn<template><div><vxe-gridref="gridRef"v-bind="gridOptions"@cell-area-selection-end="cellAreaSelectionEndEvent"@cell-area-extensio…