信纸wordpress/长春网站优化方案
作者:指针不指南吗
专栏:算法篇🐾或许会很慢,但是不可以停下🐾
文章目录
- 1. 图的存储
- 1.1 邻接矩阵
- 1.2 邻接表
- 2. 图的遍历
- 2.1 dfs 遍历
- 2.2 bfs 遍历
1. 图的存储
- 引入
一般来说,树和图有两种存储方式,树是无环连通图,树是特殊的图,这里只讲图。
图分成两种有向图和无向图
无向图:有向图建两条边,a->b , b->a
所以说,无向图是一种特殊的有向图 , 我们只讲 有向图的存储
1.1 邻接矩阵
二维数组, g[a][b]
,a 到 b 的边
比较浪费空间,适合存储 稠密图,用的比较少
1.2 邻接表
图和部分注释转自 acwing
- 代码实现
#include<bits/stdc++.h>
using namespace std;//N : 节点数量
//M:边的数量
//i : 节点的下标索引
//idx : 边的下标索引const int N=100010,M=2*N;//h[N] : 表示 第 i 个节点的 第一条边的 idx
//ne[M] : 表示 与 第 idx 条边 同起点 的 下一条边 的 idx
//e[M] : 表示 第idx 条边的 终点 表示值int h[N],e[M],ne[M],idx;void add(int a, int b) //插入一个 a->b 的边
{e[idx]=b; // 记录 加入的边 的终点节点, 记录值h[idx]=h[a]; // h[a] 表示 节点 a 为起点的第一条边的下标,ne[idx] = h[a] 表示把 h[a] 这条边接在了 idx 这条边的后面,其实也就是把 a 节点的整条链表 接在了 idx 这条边 后面;目的就是为了下一步 把 idx 这条边 当成 a 节点的单链表的 第一条边,完成把最新的一条边插入到 链表头的操作;h[a]=idx++; a节点开头的第一条边置为当前边,idx移动到下一条边
}int main()
{int n;cin>>n;memset(h,-1,sizeof h); //把每个头节点 初始化为 -1return 0;
}
2. 图的遍历
一般我们每个元素就遍历一次
两种搜索方式,每个点只遍历一次:深搜一边路走到黑
;宽搜 一层一层的搜
边的权重 都相等,则使用 bfs 找最短路
2.1 dfs 遍历
- 代码模板
#include<bits/stdc++.h>
using namespace std;const int N=100010,M=N*2; //以有向图的格式存储无向图,所以每个节点至多对应2n-2条边int n;
int h[N],e[M],ne[M],idx;
bool st[N];void add(int a,int b)
{e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}// 树 dfs 遍历 框架
void dfs(int u) //遍历以 u 为根节点的子树
{if(u==n) return ; //边界条件就是左右的点 都遍历过了for(int i=h[u];i!=-1;i=ne[i]) {int j=e[i]; // 去出当前节点编号if(!st[j]) //没有使用过,继续{st[j]=true; //改变状态dfs(j); //dfs 下一个节点,就是搜索以 j 为根节点的子树}}
}int main()
{cin>>n;memset(h,-1,sizeof h); //给头节点 初始化return 0;
}
-
例题
链接:[acwing 846.树的重心]( 846. 树的重心 - AcWing题库 )
给定一颗树,树中包含 n 个结点(编号 1∼n)和 n−1 条无向边。
请你找到树的重心,并输出将重心删除后,剩余各个连通块中点数的最大值。
重心定义:重心是指树中的一个结点,如果将这个点删除后,剩余各个连通块中点数的最大值最小,那么这个节点被称为树的重心。
输入格式
第一行包含整数 n,表示树的结点数。
接下来 n−1 行,每行包含两个整数 a 和 b,表示点 a 和点 b 之间存在一条边。
输出格式
输出一个整数 m,表示将重心删除后,剩余各个连通块中点数的最大值。
数据范围
1≤n≤10510^5105
输入样例:
9 1 2 1 7 1 4 2 8 2 5 4 3 3 9 4 6
输出样例:
4
-
思路
-
把树存在邻接表里面
-
开始找去除重心之后,使剩余几部分连通图中,每一部分节点最大数量 最小
- 我们可以通过 dfs ,找到每个子树中节点数量
- 算出一个子树的每一部分 ABC , 取他们的 最 max ,计算每一个节点的这几个部分
-
-
代码实现
#include<bits/stdc++.h> using namespace std;const int N=1e5+10,M=2*N; int n; int h[N],e[M],ne[M],idx; int ans=N; //最小值,初始化为 一个最大数 bool st[N];void add(int a,int b) {e[idx]=b,ne[idx]=h[a],h[a]=idx++; }int dfs(int u) //返回的是,去除 u 节点之后最大连通图的数量 {st[u]=true; //改变状态//size 表示子树连通块中点的数量(图中 B或者C)//sum 表示以 u 为根节点所有的子树点的数量(图中 x点+B+C)int size=0,sum=1; for(int i=h[u];i!=-1;i=ne[i]) //遍历以 u 为根节点的子树{int j=e[i]; //j 表示现在正在遍历的节点编号if (st[j]) continue; //遍历过了,跳过进行下一个st[j]=true; //改变状态int s=dfs(j); //存的是,以 j 为根节点的所有子树的中点的数量size=max(size,s); //取所有 子树中点数量最大的值 相当于比较图中的B,Csum+=s; //sum+ 扩展的子树中点的数量}size=max(size,n-sum); //相当于比较途中 各个部分 ABC 的最大值ans=min(size,ans); //取最大值的最小值return sum; //返回 以 u 为根节点的所有子树地最大值 }int main() {cin>>n;memset(h,-1,sizeof h);for(int i=0;i<n;i++){int a,b;cin>>a>>b;add(a,b),add(b,a); //注意这里是 无向图,有两条边}dfs(1); //开始遍历树cout<<ans; //输出结果return 0; }
2.2 bfs 遍历
- 代码模板
//宽搜框架
queue<int > q;
q.push(1); //把编号 1 节点放进去
while(!q.empty())
{int t=q.front();q.pop();//拓展所有t可以到的节点,邻点if(/*邻点x没有被遍历过*/){q.push(x);st[x]=1;d[x]=d[t]+1;}
}
-
例题
链接: 847. 图中点的层次 - AcWing题库
给定一个 n 个点 m 条边的有向图,图中可能存在重边和自环。
所有边的长度都是 1,点的编号为 1∼n。
请你求出 1 号点到 n 号点的最短距离,如果从 1号点无法走到 n 号点,输出 −1。
输入格式
第一行包含两个整数 n 和 m。
接下来 m 行,每行包含两个整数 a 和 b,表示存在一条从 a 走到 b 的长度为 1 的边。
输出格式
输出一个整数,表示 1 号点到 n 号点的最短距离。
数据范围
1≤n,m≤10510^5105
输入样例:
4 5 1 2 2 3 3 4 1 3 1 4
输出样例:
1
-
思路
我们第一发现这个点,就是源点到这个点的最短路径
首先判断出来 这道题是使用 bfs
然后 , 图的存储, 图的遍历 模板题
-
代码实现
#include<bits/stdc++.h> using namespace std;const int N=1e5+10,M=N*2;int n,m; //n表示点,m表示边 int h[N],e[M],ne[M],idx; bool st[N]; int q[N],d[N]; //q表示队列,d表示距离void add(int a,int b) {e[idx]=b,ne[idx]=h[a],h[a]=idx++; }int bfs() {int hh,tt; //hh表示队头,tt表示队尾q[0]=1; //存储层次遍历序列 0号节点是编号为1的节点memset(d,-1,sizeof d); //d[]==-1,表示没有被遍历过d[1]=0; //储存每个节点到 起点 编号1 的距离while(hh<=tt){//取出 队头int t=q[hh++];//遍历t节点的每一个邻边for(int i=h[t];i!=-1;i=ne[i]){int j=e[i]; if(d[j]==-1) //j 没有没被扩展过{d[j]=d[t]+1; //该点的距离+1,并且表示已经被扩展过了q[++tt]=j; //把扩展的点放到队列里面去,压入队列} }}return d[n]; //返回编号为 n 的节点到 起点的距离 }int main() {cin>>n>>m;memset(h,-1,sizeof h);for(int i=0;i<m;i++) //读入边{int a,b;cin>>a>>b;add(a,b);}cout<<bfs();return 0; }
STL 队列实现 bfs
int bfs() {queue<int> q;q.push(1);// q[0]=1; //存储层次遍历序列 0号节点是编号为1的节点memset(d,-1,sizeof d); //d[]==-1,表示没有被遍历过d[1]=0; //储存每个节点到 起点 编号1 的距离while(!q.empty()){int t=q.front();q.pop();for(int i=h[t];i!=-1;i=ne[i]){int j=e[i];if(d[j]==-1){d[j]=d[t]+1;q.push(j);}}} }
相关文章:

【算法】图的存储和遍历
作者:指针不指南吗 专栏:算法篇 🐾或许会很慢,但是不可以停下🐾 文章目录1. 图的存储1.1 邻接矩阵1.2 邻接表2. 图的遍历2.1 dfs 遍历2.2 bfs 遍历1. 图的存储 引入 一般来说,树和图有两种存储方式&#…...

文件如何批量复制保存在多个文件夹中
在日常工作中经常需要整理文件,比如像文件或文件夹重命名或文件批量归类,文件批量复制到指定某个或多个文件来中保存备份起来。一般都家最常用方便是手动一个一个去重命名或复制到粘贴到某个文件夹中保存,有没有简单好用的办法呢,…...

16N60-ASEMI高压MOS管16N60
编辑-Z 16N60在TO-220封装里的静态漏极源导通电阻(RDS(ON))为0.2Ω,是一款N沟道高压MOS管。16N60的最大脉冲正向电流ISM为48A,零栅极电压漏极电流(IDSS)为10uA,其工作时耐温度范围为-55~150摄氏度。16N60功耗…...

Open3D 多个点云配准(C++版本)
文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 多路配准(多个点云配准)是指在全局空间中对齐多个几何块的过程。输入的数据可以是点云或深度图像 P i P_i P...

java实现Hbase 增删改查
目录 一、新建一个maven工程 二、代码实现 2.1、配置hbase信息,连接hbase数据库 2.2、创建命名空间 2.3、创建表 2.4、删除表,删除之前要设置为禁用状态 2.5、添加数据 2.6、获取命令表空间 / tables列表 2.7、get方法查看表的内容 2.8、scan方法…...

1109. 航班预订统计 差分数组
1109. 航班预订统计 差分数组技巧适⽤于频繁对数组区间进⾏增减的场景 1.由数组a生成差分数组b{b[0]0,i0(或者b[0]a[0],i0)b[i]a[i]−a[i−1],i>01.由数组a生成差分数组b\left\{\begin{array}{l}b[0]0,i0(或者b[0]a[0],i0)\\ b[i]a[i]-a[i-1],i>0\end{array}\right. 1.由…...

图床搭建,使用typora上传
1. 准备gitee作为图床的仓库 新建仓库 准备仓库的私人令牌,后面配合使用 点击个人设置——》私人令牌 注意私人令牌,复制保存好,后面不能再看了 2. 准备PicGO,并进行相关配置 PicGo官方下载链接 下载安装好node.js,下载网址 安…...

低代码开发的优势是什么?
低代码开发的优势是什么?低代码开发这个概念这两年来经常出现在人们的视野中,市场对于低代码的需求也越来越庞大。 Gartner预测,到2025年,75%的大型企业将使用至少四种低代码/无代码开发工具,用于IT应用开发和公民开发计划。 可…...

Ip2Resion线上部署报数据越界及错误处理
上篇在本地测试调用Ip2Resigon解析行政区划 Ip2Region的Java本地实现运行正常,但部署到测试环境,抛出数组越界(java.lang.ArrayIndexOutOfBoundsException)异常。 环境信息 ip2Resion是2.7版本,对应文件后缀为 xdb。 …...

致敬我的C++启蒙老师,跟着他学计算机编程就对了 (文末赠书5本)
致敬我的C启蒙老师,跟着他学计算机编程就对了 摘要 讲述了一个故事,介绍了一位良师,一段因C而续写的回忆,希望对各位看官有所帮助和启发。 文章目录1 写在前面2 我的C启蒙老师3 谈谈老师给我的启发4 友情推荐5 文末福利1 写在前面…...

CSS中的伪元素和伪类
一直被伪类和伪元素所迷惑,以为是同一个属性名称,根据CSS动画,索性开始研究a:hover:after,a.hover:after的用法。 伪元素 是HTML中并不存在的元素,用于将特殊的效果添加到某些选择器。 对伪元素的描述 伪元素有两…...

逻辑优化基础-rewrite
简介 逻辑综合中的rewrite算法是一种常见的优化算法,其主要作用是通过对逻辑电路的布尔函数进行等效变换,从而达到优化电路面积、时序和功耗等目的。本文将对rewrite算法进行详细介绍,并附带Verilog代码示例。 一、算法原理 rewrite算法的…...

案例27-单表从9个更新语句调整为2个
目录 一:背景介绍 二:思路&方案 三:过程 1.项目结构 2.准备一个普通的maven项目,部署好mysql数据库 3.在项目中引入pom依赖 5.编写MyBitis配置文件 6.编写Mysql配置类 7.编写通用Update语句 8.项目启动类 四:总…...

Wordpress paid-memberships-pro plugins CVE-2023-23488未授权SQLi漏洞分析
目录 1.漏洞概述 2.漏洞等级 3.调试环境 4.漏洞代码 5 POC 1.漏洞概述 WordPress插件paid-memberships-pro版本<2.9.8中,容易受到REST路由“/pmpro/v1/order”的“code”参数中未验证的SQL注入漏洞的影响。攻击者可进行SQLi盲注,从而获取数据库权限。 CVE:...

【JavaWeb篇】JSTL相关知识点总结
目录 为什么会有JSTL? 什么是JSTL? 如何理解JSTL标准标签库呢? 如何使用JSTL? 第一步:引入JSTL标签库对应的jar包。 第二步:在JSP中引入要使用标签库。(使用taglib指令引入标签库。&#x…...

【蓝桥杯刷题】坑爹的负进制转换
【蓝桥杯刷题】——坑爹的负进制转换😎😎😎 目录 💡前言🌞: 💛坑爹的负进制转换题目💛 💪 解题思路的分享💪 😊题目源码的分享Ƕ…...

react+antdpro+ts实现企业级项目二:Strapi及认证登陆模块
在上一章节中,我们已经成功创建并登陆了系统,现在需要为系统添加权限和登录认证,以提高系统的安全性、数据保护、个性化服务和用户体验。此外,添加权限和登录认证还可以方便管理员进行用户和授权管理。为了快速开发前端࿰…...

Android ANR trace日志如何导出
什么是ANR ?上网搜索,一搜一大片,我就说个很容易识别的字眼,XXXAPP无响应 ANR trace日志如何导出?使用ADB命令: adb pull data/anr/trace.txt 你要存放的路径。查看ANR报错位置全局搜索你APP的包名&#x…...

Windows SSH 配置和SCP的使用
使用用户界面安装 ssh 功能 要在 Windows 10/11 上启用 SSH 服务器,请按照以下步骤操作: 按“Windows 键 I”打开“设置”菜单,然后选择“应用程序”。在左侧菜单栏中选择“应用和功能”。从列表中选择“可选功能”。 点击“添加功能”按钮…...

liunx 安装redsi和连接
liunx 安装redsi和连接 下载 (https://download.redis.io/releases/) 上传到 /usr/local目录 解压 tar -xvf redis-5.0.14.tar.gz 切换到 cd ./redis-5.0.14 编译 make 安装 make install 默认安装目录 /usr/local/bin/ 修改 ./redis-5.0.14/reds…...

接口里面可以写实现方法吗【可以】 、接口可以多继承吗【可以】
比如下面这道题: 问: 接口里面可以写方法吗? 答: 当然可以啊,默认就是抽象方法。 . 问: 那接口里面可以写实现方法吗? 答: 不可以,所有方法必须是抽象的。 . 问: 你确定吗࿱…...

【YOLOv8/YOLOv7/YOLOv5/YOLOv4/Faster-rcnn系列算法改进NO.57】引入可形变卷积
文章目录前言一、解决问题二、基本原理三、添加方法四、总结前言 作为当前先进的深度学习目标检测算法YOLOv8,已经集合了大量的trick,但是还是有提高和改进的空间,针对具体应用场景下的检测难点,可以不同的改进方法。此后的系列…...

统计学习--三种常见的相关系数
1)Pearson积差相关系数:用于量度两个变量X和Y之间的线性相关。它具有1和-1之间的值,其中1是总正线性相关性,0是非线性相关性,并且-1是总负线性相关性。Pearson相关系数的一个关键数学特性是它在两个变量的位置和尺度的…...

基于Django4.1.4的入门学习记录
基于Django4.1.4的入门学习记录Django创建Django项目创建工程工程目录说明运行开发服务器settings.py配置文件应用的创建创建应用模块应用模块文件说明App应用配置注册安装子应用数据模型ORM概述定义模型类生成数据库表查看数据库文件Admin管理工具管理界面本地化创建管理员注册…...

C++ Butterworth N阶滤波器设计
介绍一个 Butterworth Nth 滤波器设计系数的函数,像 Matlab 函数一样的: [bl,al]butter(but_order,Ws); 和 [bh,ah]butter(but_order,2*bandwidth(1)/fs,high);rtfilter 在 Ububtu 中,容易找到: $ aptitude search ~dbutterwo…...

UXP下不用任何框架创建自己的插件并试运行
在上一篇文章中《Windows下vue框架下的UXP插件开发环境搭建及程序试运行》,搭建的是利用vue框架进行开发的UXP开发环境,而且是把官方的案例插件直接添加进UDT,下面要说的是不利用任何js的框架创建和试运行自己的UXP插件程序,这样来…...

mac修改国内源快速安装brew
我是参考了清华源官网,有任何困惑直接访问该网址即可。这里给出精简版。 1. 更改镜像到~/.zshrc 终端添加方式 echo export HOMEBREW_API_DOMAIN"https://mirrors.tuna.tsinghua.edu.cn/homebrew-bottles/api" >> ~/.zshrcecho export HOMEBREW_…...

Me-and-My-Girlfriend-1靶场通关
Me-and-My-Girlfriend-1靶场通关 靶机ip:192.168.112.135 信息收集 端口:22、80 还是从80WEB服务器端口入手 对服务器目录进行扫描,扫出以下目录 访问80端口WEB服务,显示一段文字只允许本地用户访问。 一眼伪造ip,查看页面…...

2.6 棋盘覆盖
在一个2*x2‘个方格组成的棋盘中,若怡有一个方格与其他方格不同,则称该方格为特殊方格,且称该棋盘为一特殊棋盘。显然,特殊方格在棋盘上出现的位置有 4种情形因而对任何k0,有4‘种特殊棋盘。图2-4 申的特殊棋益是12时 …...

JMU软件20 大数据技术复习(只写了对比18提纲的变动部分)
原博主 博客主页:https://xiaojujiang.blog.csdn.net/ 原博客链接:https://blog.csdn.net/qq_43058685/article/details/117883940 本复习提纲只适用于JMU软件工程大数据课程(ckm授课) 具体内容参考老师提纲的考纲,18和…...