文章目录

    • 前言
    • 图(graph)
      • 1)图的基本概念及特性
      • 2)图的描述
        • a. 无权图描述
        • b. 加权图描述
      • 3)图的类实现
      • 4)图的遍历
        • a. 广度优先搜索
        • b. 深度优先搜索
        • c. 两种搜索算法的比较
      • 5)图的应用
        • a. 寻找一条路径
        • b. 连通及连通构件
        • c. 生成树

前言

本章是数据结构逻辑的最后一种形式,图状结构。因为本章只讲述了图结构的冰山一角,所以结构非常清晰。

图(graph)

图是最复杂的一种数据结构,也是最能表述现实应用的数据结构。人际关系、航线、网络中的节点等等许多接近实际的问题都可以用图来描述。

1)图的基本概念及特性

:在数据结构领域,我们把图抽象为有限集V和E的有序对,即用边连接在一起的顶点的集合。

就像望月新一证明ABC猜想一样,要学习图,首先要了解图的世界,清楚在图的世界中的术语。

一大堆概念来袭:

  1. 顶点(vertex)
  2. 有向边(directed edge)与无向边(undirected edge)
  3. 有向图(directed graph)与无向图(undirected graph)
  4. 邻接(adjacent)与关联(incident)
  5. 权(weight)与长度(length)
  6. 加权图(weighted graph)与无权图(unweighted graph)
  7. 环(loop)
  8. 路径(path)与简单路径(simple path)
  9. 环路(cycle)
  10. 连通(connected)、 强连通(strongly connected)
  11. 生成树(spanning tree)
  12. 度(degree)、入度(in-degree)与出度(out-degree)
  13. 完全图(complete path)与二分图(bipartite graph)

当明白这些概念都在讲什么东西的时候,我们就可以继续往下学习图的某些特性(其实仔细想一下就能推出的特性):

  • 在无向图中,所有节点的度求和 = 边的数量的二倍
  • 在有向图中,所有节点的出度求和 = 所有节点的入度求和 = 边的数量

2)图的描述

图的描述其实就是图中的元素如何存储,课本中列举了三种方法,同时这三种方法在在矩阵那一章也出现过。

  1. 邻接矩阵(adjacent matrix):设图中有n个元素,利用(n+1)(n+1)(n+1)*(n+1)的二维数组进行存储。
  2. 邻接链表(adjacent list):将图中的节点存储在一个一维数组中,数组中的元素ii指向一个链表指针,该链表中存储ii的邻接节点。
  3. 邻接数组(adjacency array):将图中的节点存储在一个一维数组中,数组中的元素ii指向一个数组指针,该数组中存储ii的邻接节点。该二维数组是不规则的。

a. 无权图描述

以下图为例
在这里插入图片描述

邻接矩阵:

在这里插入图片描述
邻接链表:
在这里插入图片描述
邻接数组:
在这里插入图片描述

b. 加权图描述

以下图为例:
在这里插入图片描述
邻接矩阵:
在这里插入图片描述
邻接链表:
在这里插入图片描述
邻接数组
与无权图的不同是,将数组的对象由T类型改为结构体或pair类型。

3)图的类实现

图的分类:无权无向图、加权无向图、无权有向图、加权有向图
图的描述:邻接矩阵、邻接链表、邻接数组

对于每一种图,都有三种描述与之对应,共有12种类。

类继承图关系如下:
在这里插入图片描述
因为图的类实现实在太多,函数也由于描述不同不能实现通用,且函数逻辑都较为简单。我在这里仅写出抽象类 Graph作为参考,以防忘记。

template <class T>class Graph
{
public:virtual ~graph(){}//ADTvirtual int numberOfVertices() const = 0; // 返回节点数量virtual int numberOfEdges() const = 0; // 返回边的数量virtual bool existsEdge(int, int) const = 0; // 判断一条边是否存在virtual void insertEdge(edge<T>*) = 0; // 插入边virtual void eraseEdge(int, int) = 0; // 删除边virtual int degree(int) const = 0; // 返回某一节点的度virtual int inDegree(int) const = 0; // 返回某一节点的入度virtual int outDegree(int) const = 0; // 返回某一节点的出度virtual bool directed() const = 0; // 当是有向图时,返回truevirtual bool weighted() const = 0; // 当是加权图时,返回truevirtual vertexIterator<T>* iterator(int) = 0;// 迭代器,访问指定顶点的相邻节点
};

4)图的遍历

图的遍历即从某一顶点开始,寻找所有可到达的顶点。有两种常用的搜索方法:广度优先搜索(BFS,breadth first search)和深度优先搜索(DFS, deep first search)

a. 广度优先搜索

广度优先搜索利用队列结构,从特定节点开始,遍历所有邻接节点,标记并入队。再依次出队,对于每一个出队的节点,遍历其所有未标记的邻接节点,标记并入队,直到队列为空,算法结束。

因为队列的FIFO属性,搜索过程是宽度优先,即第一次遍历的节点都是和起始节点“距离”为1的节点,第一次遍历入队的节点出队为第二次遍历,第二次都是“距离”为2的节点,第三次…
所以叫做广度优先搜索。


virtual void bfs(int v, int reach[], int label)
{Queue<int> q;reach[v] = label;q.push(v);while(!q.empty()){int p = q.pop();//使用迭代器来找到顶点p的所有邻接节点vertexIterator<T>* ip = iterator(p);int tem;while((tem = ip->next()) != 0){if(reach[tem] == 0){q.push(tem);reach[u] = label;}}delete ip;}
}

b. 深度优先搜索

深度优先搜索利用栈结构,可以利用递归或者非递归实现。如果使用栈,那么从特定节点开始,遍历其所有邻接节点,标记并加入栈。再依次出栈,对于每个出栈的元素,遍历其未标记的邻接节点,标记并入队,栈为空时,算法结束。

因为栈结构的FILO属性,从初始节点开始,遍历的元素入栈后反向出栈,在每次遍历都有新节点的情况下,每一次出栈的元素与初始点的“距离”都加一。若一次遍历没有发现新节点,下一次出栈的元素较上次出栈的元素“距离”减一。
因为是一股劲冲到最远“距离”,碰壁之后退一格再继续冲,所以叫做深度优先搜索。

// 递归实现
virtual void dfs(int v, int reach[], int label)
{Graph<T>::reach = reach; //reach和label为静态数据成员Graph<T>::label = label;rDfs(v);
}virtual void rDfs(int v)
{reach[v] = label;vertexIterator<T> *iv = iterator(v);int u;while((u=iv->next()) != 0){if(reach[u] == 0)rDfs(u);}delete iv;
}// 非递归实现
virtual void SDfs(int v, int reach[], int label)
{Stack<int> s;reach[v] = label;s.push(v);while(!s.empty()){int p = s.pop();vertexIterator<T> *ip = iterator(p);int tem;while((tem = ip->next()) != 0){if(reach[tem] == 0){s.push(tem);reach[tem] = label;}}delete ip;}
}

c. 两种搜索算法的比较

时间复杂度:两种搜索算法的时间复杂度在相同描述下是相同的。在上述的代码中,时间复杂度取决于加入容器的节点数目和迭代器用时。

  • 当使用邻接矩阵实现时,时间复杂度为O(sn)O(sn),ss是加入容器的节点数目。
  • 当使用邻接链表或邻接数组实现时,时间复杂度为idiout\sum_{i}d_{i}^{out},其中i是被标记的节点。

空间复杂度:两种搜索算法的空间复杂度都为O(n)O(n)。其中有个有趣的现象是两种算法空间性能最好和最坏的情况是相反的。

如下图:
在这里插入图片描述
以1为起始点,

  • 图a是dfs最坏的情况,因为在到达n之前都不能释放栈空间;同时又是bfs最好的情况,队列中的元素在算法执行时永远不超过1。
  • 图b是bfs最坏的情况,因为第一次遍历之后,队列中的元素达到n1n-1;同时又是dfs最好的情况,栈空间在算法执行时永远不超过1。

5)图的应用

说是图的应用,其实更像是两种搜索算法的应用。

a. 寻找一条路径

寻找一条从源点到目标节点的路径。
可以通过bfs和dfs实现两种不同寻找路径的方法,其中dfs找出的不一定是最短路径,bfs找出的一定是最短路径。

dfs递归实现

//dfs寻找路径,节点为int类型,返回一个int类型的路径数组
int* findPath_dfs(int source, int goal)
{int n = numberOfVertices();int* path = new int[n+1];path[1] = source;int* reach = new int[n+1];for(int i = 1; i<=n; i++){reach[i] = 0;}//搜索路径if(theSource == goal || rFindPath(source,goal)){path[0] = length - 1;}else{delete[] path;path = null;}delete[] path;return path;
}bool rFindPath(int source, int goal)
{reach[source] = 1;vertexIterator<T>* is = iterator(source);int u;while((u = is->next()) != 0){if(reach[u] == 0){path[++length] = u;if(u = goal || rFindPath(u, goal))return true;length--;}}delete is;return false;
}

bfs实现:

//使用bfs寻找最短路径,只需要加一个记录前驱节点的数组int* findPath_bfs(int source, int goal)
{Queue<int> q;int* path = new int[n+1];int* pre = new int[n+1];int* reach = new int[n+1];for(int i =0;i<=n;i++){reach[i] = 0;pre[i] = 0;}q.push(source);while(!q.empty()){int p = q.pop();vertexIterator<T> *ip = iterator(p);int u;while((u = ip->next()) != 0){if(reach[u]==0){q.push(u);reach[u] = 1;pre[u] = p;if(u == goal)break;}}if(u == goal)break;}int t = pre[q.pop()];int i = 1;path[i++] = t;t = pre[t];while(t != 0){path[i++] = t;t = pre[t];}return path;
}

b. 连通及连通构件

搜索方法另一应用是检验无向图是否连通,或者对一个不连通图的连通构件进行标记,判断哪几个节点在同一构件中。

判断是否连通算法的思想十分简单:

//判断是否连通
bool connected()
{int n = numberOfVertices();int* reach = new int[n+1];dfs(1, reach,1);for(int i = 1; i <= n; i++){if(reach[i] == 0)return false;}return true;
}

判断连通构件个数:

int labelComponents()
{int n = numberOfVertices();int label = 0;int* reach = new int[n+1];for(int i = 1; i <= n; i++){if(reach[i] == 0){label++; // 区分连通构件和记录构件数bfs(i, reach, label);}}return label;
}

c. 生成树

进行bfs或dfs时,每遍历一个未到达过的节点,前序节点和该节点形成一个edge。因为不可能遍历已到达的节点,形成的边集不可能有环路,并且由搜索算法可知该边集又是连通的,算法结束后形成一颗树,我们叫做生成树

由bfs形成的叫做广度优先生成树,由dfs形成的叫做深度优先生成树。

在这里我们只介绍什么是生成树,以后的章节会利用Prim算法和Kruskal算法,寻找最小生成树。

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

相关文章

  1. Number Challenge CodeForces - 235E(莫比乌斯反演,约数函数性质)

    学习地址 总结:莫比乌斯反演的题目是很有套路的,要学会从枚举约数到枚举倍数的改变,另外这里的约数函数的等价式需要记下。 const int N = 2e3+5; ll mo = 1ll<< 30; int p[N + 1], mob[N + 1], cnt,d[N][N]; bool vis[N + 1]; void x_x() {mob[1] = 1;f(i, 2, N){if …...

    2024/4/15 14:32:46
  2. LeetCode题解(0591):标签合法性检测器(Python)

    题目:原题链接(困难) 标签:字符串、正则表达式解法 时间复杂度 空间复杂度 执行用时Ans 1 (Python) – – 36ms (96.00%)Ans 2 (Python)Ans 3 (Python)LeetCode的Python执行用时随缘,只要时间复杂度没有明显差异,执行用时一般都在同一个量级,仅作参考意义。解法一(正则…...

    2024/4/15 14:32:46
  3. [算法]串的模式匹配方法BF与KMP

    串的模式匹配方法BF与KMP前言前置约定BF匹配算法算法思路示意动画代码解析存在的问题KMP匹配算法改进思路回顾BF不回溯的替代方案右移规律一句话描述示意动画next表的构建代码解析KMP算法主体代码解析nextval计算作用计算方法总结参考资料 前言KMP算法并不好理解,读者尽量选择…...

    2024/4/15 14:32:45
  4. 背包方案数问题

    ala的杂货店(开店第三天) Description m元钱来买东西,n种物品中每种物品有一个对应的价格,想知道花光m元钱可以购买的物品方案总数。 Input 数据为单组 数据的第一行有两个整数,分别为n件物品和m元钱(1<=n<=200,1<=m<=200) 第i行为第i种物品的价格w[i]元(1&l…...

    2024/5/5 1:02:45
  5. 学习笔记 —— DIV + CSS 网页布局知识整理

    HTML 介绍 HTML 是什么? HTML 指的是超文本标记语言(英文:HyperText Markup Language),是用来描述网页的一种语言。HTML 不是一种编程语言,而是一种标记语言,它有一套标记标签。 HTML 使用标记标签来描述网页。 HTML 文档包含了 HTML 标签及文本内容,HTML 文档也叫做 W…...

    2024/4/17 16:57:45
  6. 精准努力,我该如何去做?

    精准努力,我该如何去做? 刘媛媛,超级演说家第二季总冠军,北京大学法律系研究生。《精准努力,刘媛媛的逆袭课》这本书我是通过微信读书这个软件看到的,从头到尾大概花了一周的时间。整本书覆盖范围非常广,从思想的塑造,到时间的管理,再到社交技巧等,可以看得出,这本书…...

    2024/4/15 14:32:54
  7. 微服务(非代码)服务发现与注册中心和Eureka详解

    服务发现与注册中心-Eureka详解 文章目录服务发现与注册中心-Eureka详解SpringCloud理论技术概述主流技术栈服务注册与发现1、为什么使用服务发现?2、服务发现模式客户端服务发现模式服务器端服务发现模式4、服务注册表(Service Registry)5、服务注册(Service Registration…...

    2024/5/4 19:41:03
  8. 【计算机科学与技术】信息论笔记(8):率失真理论

    200804本篇是学习信息论的入门笔记,希望能与各位分享进步!这是第八章:率失真理论~文章目录8. 率失真理论8.1 量化8.2 定义8.3 率失真函数的计算 8. 率失真理论离散信源的有损压缩:信道描述Q=(q(bj∣aK))KJQ=(q(b_j | a_K))_{K\times J}Q=(q(bj​∣aK​))KJ​。 连续信源:输…...

    2024/4/15 19:01:37
  9. gcc 源码分析-从一个最简单的程序说起1

    本节将以一个最简单的函数来分析gcc 的执行过程,这个函数没有函数体,也没有传入的参数。 例子如下:void main( ){}首先作词法分析:我们这里没有按照gcc源代码的做法,用手工做词法分析,而是采用采用词法分析工具flex,来完成词法分析,这样做的结果,代码看起来很简洁直观…...

    2024/5/1 21:14:52
  10. esxi 6.5 启动错误 Error loading /state.tgz

    问题: esxi 的主机重启后出现以下错误:网上主要的说法是服务器意外关机导致的, 解决办法,重装 esxi 系统。 在安装过程中可以选择不覆盖原存储盘,那以前的虚拟机和文件都不会丢失。 但是这样太麻烦了, 通过研究发现esxi有两个250M左右的盘,其中一个就是包含了文件 state…...

    2024/4/29 11:45:19
  11. 210. 课程表 II Course Schedule II

    题目 https://leetcode-cn.com/problems/course-schedule-ii/和之前修改不多。。。struct Node{int val;struct Node *next; };struct Stack{struct Node *top; };struct Stack *StackCreate(){struct Stack *obj = malloc(sizeof(struct Stack));memset(obj,0,sizeof(struct S…...

    2024/4/15 19:01:36
  12. i18n 国际化

    1、什么是 i18n 国际化? 国际化(Internationalization)指的是同一个网站可以支持多种不同的语言,以方便不同国家,不同语种的用户访问。 关于国际化我们想到的最简单的方案就是为不同的国家创建不同的网站,比如苹果公司,他的英文官网是: http://www.apple.com而中国…...

    2024/5/1 17:50:25
  13. 腾讯地图仿微信发送位置功能

    以下内容转载自面糊的文章《模仿微信发送位置功能》 作者:面糊 链接:https://www.jianshu.com/p/47b3ada2e36d 来源:简书 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。前言 微信的发送位置功能是一个十分方便的功能,他会定位用户当前所在地点,然…...

    2024/4/15 19:01:32
  14. 如何在Excel表格中创建下拉选项

    在WPS中:1.选择相应的单元格,点击菜单栏中的“数据”>“插入下拉列表”,即可添加下拉列表...

    2024/4/15 19:01:31
  15. python利用Opencv resize批量裁剪图片与重命名

    个人笔记 代码如下 import cv2 import os.path import osclass BatchRename():def __init__(self):self.path = /media/nvidia/0656602C56601EA5/ceshi/indir/#需更改文件地址,结尾需要有一定要有/def rename(self)filelist = os.listdir(self.path)#获取路径i = 0#图片初始名…...

    2024/5/1 12:28:50
  16. 云计算教程学习入门,云计算用户如何使用云服务产品?

    现在的企业运用技术中传统的应用正在变得越来越复杂:需要支持更多的用户,需要更强的计算能力,需要更加稳定安全等等,而为了支撑这些不断增长的需求,企业不得不去购买各类硬件设备(服务器,存储,带宽等等)和软件(数据库,中间件等等)。另外企业还需要组建一个完整的运…...

    2024/4/22 1:40:00
  17. angular通过platform获取操作系统版本

    现在项目要实现一个功能,android 1.x - 5.x , ios 1.x -10.x 的情况下网站不可访问,但是会进入一个假画面。功能就是怎么实现判断操作系统和版本,通过 platform.js 库可以轻松实现比原生的要简单的多。首先将下载好的 platform.js 放到 assets\js 目录下调用方法:import * …...

    2024/4/19 19:49:10
  18. leaflet:入门基础(五)之结束篇

    前言到此差不多把 leaflet 官方入门教程中的一些案例写完了,接下来把剩余的一些案例简单说一下。官方教程:Leaflet Tutorials交互式地图程序在接受到编程人员相应的指令后而相应地做出反应,这一过程及行为,我们称之为交互。在这张美国人口密度图中,我们指到哪个州,就会告…...

    2024/4/15 14:33:05
  19. 云计算教程学习入门视频课件:云服务有多安全?

    云服务管理是指云服务提供商必须履行的一套流程和任务,以便圆满地把云服务交付给消费者。云计算能节约成本,快速满足用户对资源的弹性需求,这使得一些潜在的云服务消费者有兴趣把计算迁入云端。然而,这些潜在的云服务消费者能否变成真实的云服务消费者,在很大程度上依赖于…...

    2024/5/2 3:58:22
  20. sql中完全依赖,部分依赖,传递依赖关系

    以学生表的几个简单例子介绍一下,说明:Sno(学生学号),Sname(学生姓名),Sdept(学生所在院系),Cno(课程号),Grade(课程成绩),Mname(系主任名字)1.完全依赖:一个学号就可以决定一个学生姓名(将决定用→表示),Sno→Sname,这样就叫做Sname完全依赖于Sno,同样还有S…...

    2024/5/1 20:19:12

最新文章

  1. RKNN Toolkit2 工具的使用

    RKNN Toolkit2 是由瑞芯微电子 (Rockchip) 开发的一套用于深度学习模型优化和推理的工具。它主要面向在瑞芯微SoC上进行AI应用开发&#xff0c;但也可以用于PC平台进行模型的转换、量化、推理等操作。它支持将多种深度学习框架的模型&#xff08;如Caffe, TensorFlow, PyTorch等…...

    2024/5/5 2:30:11
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. ModStartCMS(支持Laravel 9)v8.3.0

    ModStart 是一个基于 Laravel 模块化极速开发框架。模块市场拥有丰富的功能应用&#xff0c;支持后台一键快速安装&#xff0c;让开发者能快的实现业务功能开发。 系统完全开源&#xff0c;基于 Apache 2.0 开源协议&#xff0c;免费且不限制商业使用。 功能特性 丰富的模块市…...

    2024/5/4 5:27:17
  4. 与机器对话:ChatGPT 和 AI 语言模型的奇妙故事

    原文&#xff1a;Talking to Machines: The Fascinating Story of ChatGPT and AI Language Models 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 从 ELIZA 到 ChatGPT&#xff1a;会话式人工智能的简史 会话式人工智能是人工智能&#xff08;AI&#xff09;的一个分…...

    2024/5/2 18:14:02
  5. HIS系统是什么?一套前后端分离云HIS系统源码 接口技术RESTful API + WebSocket + WebService

    HIS系统是什么&#xff1f;一套前后端分离云HIS系统源码 接口技术RESTful API WebSocket WebService 医院管理信息系统(全称为Hospital Information System)即HIS系统。 常规模版包括门诊管理、住院管理、药房管理、药库管理、院长查询、电子处方、物资管理、媒体管理等&…...

    2024/5/1 13:22:01
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/4 12:05:22
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/4 11:23:32
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/4 14:46:16
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/4 23:54:44
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/4 12:10:13
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/4 23:54:49
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/4 23:54:44
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/4 14:46:12
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/4 14:46:11
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/4 14:46:11
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/5 2:25:33
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/4 21:24:42
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/4 12:39:12
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/4 13:16:06
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/4 16:48:41
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/4 14:46:05
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/4 2:00:16
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/4 23:54:30
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/4 9:07:39
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/4 14:46:02
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57