揉捻Map-疯狂Java

news2024/12/28 6:02:15

理论概述

定义

图(Graph)是由节点(Vertex)和连接节点的边(Edge)组成的一种非线性数
据结构。它用于描述事物之间的关系、连接或依赖。图是一种非线性的数据结构,
它广泛应用于计算机科学、数学、工程等领域。

在这里插入图片描述

基本概念

节点(Node):也称为顶点(Vertex),表示图中的一个对象或实体。节点可以
代表人、地点、物体或抽象概念等。节点可以有属性和标签。

边(Edge):也称为连接(Link)或关系(Relation),表示节点之间的连接
或相互关系。边可以是有向或无向的,有向边有一个起点和一个终点,无向边表
示双向关系。

加权图(Weighted Graph):图中的边可以带有权重或成本,表示两个节点之
间的距离、耗费或其他度量。

路径(Path):图中的路径是由一系列边连接的节点序列。路径的长度可以通过
边的数量或边上的权重来衡量。

入度(In-degree)和出度(Out-degree):在有向图中,每个节点有一个入度
(指向该节点的边的数量)和一个出度(从该节点发出的边的数量)。

在这里插入图片描述

图的类型

加权图(Weighted Graph):图中的边带有权重或成本,表示节点之间的距离、
耗费或其他度量。权重可以是实数、整数或其他类型的值。

无权图(Unweighted Graph):图中的边没有权重,只表示节点之间的连接关
系,不考虑边的权重值。

完全图(Complete Graph):在无向图中,任意两个节点之间都有边相连,形
成完全图。具有n个节点的完全图有n(n-1)/2条边。

稀疏图和稠密图(Sparse Graph and Dense Graph):稀疏图指的是边的数量
相对较少的图,而稠密图指的是边的数量相对较多的图。

有环图和无环图(Cyclic Graph and Acyclic Graph):有环图包含至少一个
环(循环)的图,即可以沿着边形成一个回路。无环图没有任何环。

连通图和非连通图(Connected Graph and Disconnected Graph):连通图
指的是图中任意两个节点之间都存在路径的图,非连通图则存在节点不可达的情
况。可以把非连通图划分为多个连通子图。

强连通图和弱连通图(Strongly Connected Graph and Weakly Connected
 Graph):强连通图是有向图中,任意两个节点之间都存在双向路径的图。弱连
 通图是在将有向图中的边的方向忽略后形成的连通图。

生成树(Spanning Tree):生成树是一个无环连通子图,包含了原图中所有节
点,并且通过最少的边连接这些节点。

在这里插入图片描述

表示方法

邻接矩阵(Adjacency Matrix):

邻接矩阵是一个二维数组,用于表示图中节点之间的连接关系。矩阵的行和列分
别对应图中的节点,在相应的位置上使用0或1表示节点之间是否有边相连。如果
是加权图,则可以使用权重值来代替1。

在这里插入图片描述

优点:

邻接矩阵易于理解和实现。
可以快速查找节点之间是否有边相连,时间复杂度为O(1)。
适用于稠密图。

缺点:

对于大规模的稀疏图,邻接矩阵会占用较大的存储空间。
插入和删除边的操作比较耗时,时间复杂度为O(1)。

邻接表(Adjacency List):

邻接表是一种链表数组的形式,用于表示图中每个节点的邻接节点。每个节点都
有一个链表,链表中存储着与该节点相连的其他节点。

优点:

邻接表表示方法可以有效地表示稀疏图,节省存储空间。
插入和删除边的操作效率较高,时间复杂度为O(1)。
适用于大多数实际应用中的图结构。

缺点:

查找节点之间是否有边相连的操作较慢,时间复杂度为O(V),其中V是节点的数
量。
无法直接获取节点的入度和出度。

关联矩阵(Incidence Matrix):

关联矩阵是一个二维数组,用于表示图中的节点和边之间的关联关系。矩阵的行
表示节点,列表示边,当节点与边相连时,相应的位置上使用1表示。

优点:

可以表示多重图,即允许同一对节点之间存在多条边的图。
可以通过统计列向量或行向量来获取节点的入度和出度。

缺点:

占用较大的存储空间。
无法直接获取节点之间的连接关系。

其他表示方法:

邻接集合(Adjacency Set):使用集合来表示每个节点与其邻居节点之间的连
接关系。
邻接字典(Adjacency Dictionary):使用字典来表示每个节点与其邻居节点
之间的连接关系。

在这里插入图片描述

应用场景

图在各个领域都有广泛的应用,以下是一些常见的图应用以及它们的详细介绍:

1、社交网络分析:

社交网络分析是对社交网络结构和社交行为进行建模和分析的过程。通过将社交
关系表示为图,可以研究网络的特征、社区发现、信息传播、影响力分析等。社
交网络分析在社交媒体、营销、社会学等领域具有重要意义。

2、路由和通信网络:

图在路由和通信网络中起着核心作用。将网络设备和连接表示为图中的节点和边,
可以分析网络的拓扑结构和性能特征,开发高效的路由算法,以实现快速且可靠
的数据传输和通信。

3、推荐系统:

基于图的推荐系统利用用户和物品的关系构建推荐图。通过分析图中的节点和边,
推荐系统可以识别用户的兴趣、发现相似物品或用户,从而向用户提供个性化的
推荐。这在电子商务、社交媒体和内容推荐中具有重要作用。

4、地图和导航系统:

图在地图和导航系统中被广泛使用。将道路、地理位置和交通网络表示为图,可
以应用最短路径算法来实现导航和路径规划。这对于交通管理、智能交通系统和
导航应用至关重要。

5、数据库和知识图谱:

图数据库和知识图谱使用图来存储实体(节点)和它们之间的关系(边)。通过
图的查询和分析,可以揭示实体之间的复杂关系,支持数据探索、问题解决和知
识发现。这对于知识图谱、智能推理和大数据分析非常关键。

6、组织结构和关系分析:

将组织结构、业务流程和关系网络表示为图,可以揭示组织内部的关系、层次结
构和流程,辅助决策制定、流程优化和组织管理。这在组织学、人力资源管理和
流程改进中具有重要意义。

7、生物网络和蛋白质相互作用:

图在生物学中用于表示基因、蛋白质和它们之间的相互作用关系。通过分析生物
网络的拓扑结构和功能特征,可以理解生物体内的调控机制、疾病发展和药物研
发。这对于系统生物学和药物研究非常重要。

8、可视化和图形表示:

图可用于可视化和图形表示数据。通过将数据表示为节点和边的形式,可以创建
图形图表和网络图,直观地展示数据的关系和模式。这对于数据可视化、信息图
表和交互性数据探索非常有用。

补充

这些应用只是图在不同领域中的一些例子。图的应用范围非常广泛,为我们理解
和解决复杂问题提供了强大的工具和方法。

注意事项

数据预处理: 在应用图之前,需要对原始数据进行预处理。这包括数据清洗、去
除噪声、处理缺失数据和异常值等。预处理步骤可以提高数据的质量,减少后续
分析的偏差和误差。
图的表示方式选择: 根据具体问题和应用场景,选择合适的图表示方式。邻接矩
阵适用于稠密图,邻接表适用于稀疏图,关联矩阵适用于多重图,而邻接集合或
邻接字典适用于特定的操作和查询需求。
图的存储和计算效率: 图的存储和计算效率是处理大规模图的关键因素。使用合
适的数据结构和算法可以减少存储空间和计算复杂性。例如,压缩存储技术可以
有效减少稀疏图的存储空间。
并行和分布式处理: 对于大规模图数据,采用并行计算或分布式处理方法可以
显著提高处理速度和计算能力。这包括使用并行算法、分布式图处理框架和分
布式存储系统等。
图算法的选择和调优: 不同的图算法适用于不同的问题和场景。在选择算法时,
要考虑算法的时间复杂性、空间复杂性、精度和可扩展性。有时需要对算法进
行调优和参数调节,以满足特定需求。
可视化的交互性和表达力: 当使用图进行可视化时,要关注图的交互性和表达
力。交互性可以帮助用户探索和发现图中的模式和关系,而表达力则要求选择
合适的视觉编码和布局算法,以清晰、准确地呈现数据。
基准测试和验证: 在应用图算法和技术时,进行基准测试和验证非常重要。通过
比较不同算法的性能、结果和准确性,可以评估其优劣并选择最适合的算法。
此外,需要针对具体问题进行验证和验证结果的可信性。
隐私和安全性: 如果图数据涉及敏感信息,应考虑隐私和安全性问题。确保对图
数据进行适当的加密、脱敏和访问控制,以防止未经授权的访问和数据泄露。
不同图算法的特性: 不同的图算法有不同的特性和适用范围。有些算法适用于全
局图分析,如图遍历和图搜索算法;有些算法适用于局部图分析,如图聚类和图
中心性算

在这里插入图片描述

代码实现

该代码包括图的创建、添加边、获取邻居节点等基本操作:

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

class Graph {
    private Map<Integer, List<Integer>> adjacencyList;

    // 构造函数,初始化图
    Graph() {
        adjacencyList = new HashMap<>();
    }

    // 添加节点到图
    void addVertex(int vertex) {
        adjacencyList.put(vertex, new ArrayList<>());
    }

    // 添加边到图
    void addEdge(int source, int destination) {
        if (!adjacencyList.containsKey(source) || !adjacencyList.containsKey(destination)) {
            throw new IllegalArgumentException("节点不存在");
        }
        adjacencyList.get(source).add(destination);
        adjacencyList.get(destination).add(source);
    }

    // 获取邻居节点列表
    List<Integer> getNeighbors(int vertex) {
        if (!adjacencyList.containsKey(vertex)) {
            throw new IllegalArgumentException("节点不存在");
        }
        return adjacencyList.get(vertex);
    }
}

public class Main {
    public static void main(String[] args) {
        Graph graph = new Graph();

        // 添加节点到图
        graph.addVertex(0);
        graph.addVertex(1);
        graph.addVertex(2);
        graph.addVertex(3);

        // 添加边到图
        graph.addEdge(0, 1);
        graph.addEdge(0, 2);
        graph.addEdge(1, 2);
        graph.addEdge(2, 3);

        // 获取节点的邻居节点列表
        List<Integer> neighbors = graph.getNeighbors(2);
        System.out.println("节点2的邻居节点列表:" + neighbors);
    }
}

下面展示了如何使用邻接表来表示图,并实现了广度优先搜索(BFS)和深度优先搜索(DFS)算法。

import java.util.*;

class Graph {
    private int V; // 图中节点的数量
    private LinkedList<Integer> adjList[]; // 邻接表表示边的列表

    // 构造函数,初始化图
    Graph(int v) {
        V = v;
        adjList = new LinkedList[v];
        for (int i = 0; i < v; ++i)
            adjList[i] = new LinkedList();
    }

    // 添加一条边到图
    void addEdge(int v, int w) {
        adjList[v].add(w);
    }

    // 广度优先搜索遍历图
    void BFS(int s) {
        boolean visited[] = new boolean[V];
        LinkedList<Integer> queue = new LinkedList<Integer>();

        visited[s] = true;
        queue.add(s);

        while (queue.size() != 0) {
            s = queue.poll();
            System.out.print(s + " ");

            Iterator<Integer> i = adjList[s].listIterator();
            while (i.hasNext()) {
                int n = i.next();
                if (!visited[n]) {
                    visited[n] = true;
                    queue.add(n);
                }
            }
        }
    }

    // 深度优先搜索遍历图
    void DFS(int v) {
        boolean visited[] = new boolean[V];
        DFSUtil(v, visited);
    }

    // 辅助函数,递归实现深度优先搜索
    void DFSUtil(int v, boolean visited[]) {
        visited[v] = true;
        System.out.print(v + " ");

        Iterator<Integer> i = adjList[v].listIterator();
        while (i.hasNext()) {
            int n = i.next();
            if (!visited[n]) {
                DFSUtil(n, visited);
            }
        }
    }
}

public class Main {
    public static void main(String args[]) {
        Graph graph = new Graph(4);

        // 添加边到图
        graph.addEdge(0, 1);
        graph.addEdge(0, 2);
        graph.addEdge(1, 2);
        graph.addEdge(2, 0);
        graph.addEdge(2, 3);
        graph.addEdge(3, 3);

        System.out.println("广度优先搜索遍历结果:");
        graph.BFS(2);

        System.out.println("\n深度优先搜索遍历结果:");
        graph.DFS(2);
    }
    ```

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Day_71-76 BP 神经网络

目录 一. 基础概念理解 1. 一点个人理解 2. 神经网络 二. bp神经网络的局部概念 1. 神经元 2. 激活函数 三. bp神经网络的过程 1. 算法流程图 2. 神经网络基础架构 2.1 正向传播过程 2.2 反向传播过程&#xff08;算法核心&#xff09; 四. 基本bp神经网络的代码实现 1. 抽象…

一文了解 MySQL 全新版本模型

MySQL 8.1 已经发布了&#xff0c;也宣布 MySQL 开始使用新的版本模型。 作者&#xff1a;Kenny Gryp / Airton Lastori MySQL 产品团队。 原文&#xff1a;https://blogs.oracle.com/mysql/post/introducing-mysql-innovation-and-longterm-support-lts-versions 引子 在 Ora…

边缘提取总结

边缘提取&#xff1a;什么是边缘&#xff1f; 图象的边缘是指图象局部区域亮度变化显著的部分&#xff0c;该区域的灰度剖面一般可以 看作是一个阶跃&#xff0c;既从一个灰度值在很小的缓冲区域内急剧变化到另一个灰度相 差较大的灰度值。 边缘有正负之分&#xff0c;就像…

React AntDesign表批量操作时的selectedRowKeys回显选中

不知道大家是不是在AntDesign的某一个列表想要做一个批量导出或者操作的时候&#xff0c;发现只要选择下一页&#xff0c;即使选中的ids 都有记录下面&#xff0c;但是就是不回显 后来问了chatGPT&#xff0c;对方的回答是&#xff1a; 在Ant Design的DataTable组件中&#xf…

java必学必会之static关键字

java必学必会之static关键字 一、static关键字 原来一个类里面的成员变量&#xff0c;每new一个对象&#xff0c;这个对象就有一份自己的成员变量&#xff0c;因为这些成员变量都不是静态成员变量。对于static成员变量来说&#xff0c;这个成员变量只有一份&#xff0c;而且这…

Tiny Player (js) - 轻量好用、免费开源的 web 视频播放开发组件,内置硬解、软解视频功能

一款简单好用的 JS 视频播放器&#xff0c;完美解决我遇到的移动端播放视频的需求&#xff0c;安利给各位。 关于 Tiny Player Tiny Player 是一个极简的视频播放器 JS 库&#xff0c;内置硬解、软解视频功能&#xff0c;支持原生控件样式以及自定义控件样式&#xff0c;小巧…

一种代码逻辑表达“新范式”:保留编程逻辑,去掉编程语法

逻辑是一个非常古老的话题&#xff0c;很难看到有什么新的东西&#xff0c;特别是新的表达方式。最近被惊艳到了&#xff0c;在分析iVX产品的时候&#xff0c;发现了一种全新的可视化的“逻辑表达范式&#xff08;或者说新方法&#xff09;”。看下面有GIF动图演示。 理论上包括…

macbook 软件iMovie for Mac(专业视频剪辑工具)中文版

iMovie mac中文版是一款针对Mac平台量身定做的视频编辑工具&#xff0c;软件凭借流线型设计和直观的编辑功能&#xff0c;可以让您感受前所未有的方式制作好莱坞风格的预告片和精美电影&#xff0c;并且还可以浏览视频资料库&#xff0c;快速共享挚爱瞬间&#xff0c;创建精美的…

手机缺流量?切记,不要买这种卡!

近日&#xff0c;小编在后台看到很多朋友的私信&#xff0c;都在控诉买的流量卡有套路&#xff0c;通过大家的描述&#xff0c;小编发现&#xff0c;很多朋友都是“病急乱投医&#xff0c;犯了一个最大的错误”&#xff0c;只看价格&#xff0c;不看正规性。 ​ 现在网上可能上…

DDL\DML

查询字段 1、查询指定字段 select 字段1, 字段2 ,...] from 表名; select ename, sal from emp; select ename from emp; 2、查询全部字段 select * from 表名; select * from emp; 条件查询 使用 where 语句&#xff0c;放在 from 后 select * from emp where 条件…

UI 自动化稳定性用例实战经验分享!

目录 前言&#xff1a; 大家常说 UI 自动化不稳定&#xff0c;那又如何提高稳定性呢&#xff1f; 操作界面非预期的弹框、广告、浮层 测试系统的 A/B 策略 总结&#xff1a; 前言&#xff1a; 稳定性测试是软件测试的一个重要方面&#xff0c;它旨在评估软件在不同负载和…

[BSidesCF 2020]Had a bad day1

进入环境&#xff0c;一上来就是一段激励的话&#xff0c;没有啥特别的&#xff0c;源码中也没有看见啥有用的提示 但主要是有&#xff0c;参数的传递&#xff0c;加上前面的index.php&#xff0c;想到了PHP伪协议&#xff0c;或许我们可以直接查看一下隐藏源码 报错了&#xf…

nfs服务器的描述,搭建和使用

前言 这是我在这个网站整理的笔记&#xff0c;关注我&#xff0c;接下来还会持续更新。 作者&#xff1a;RodmaChen nfs服务器的描述&#xff0c;搭建和使用 NFS概述工作原理优缺点 nfs服务器搭建服务端客户端 NFS概述 NFS&#xff08;Network File System&#xff09;是一种基…

GPT-3.5:ChatGPT的奇妙之处和革命性进步

&#x1f337;&#x1f341; 博主 libin9iOak带您 Go to New World.✨&#x1f341; &#x1f984; 个人主页——libin9iOak的博客&#x1f390; &#x1f433; 《面试题大全》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33…

【Koa】[NoSQL] Koa中相关介绍和使用Redis MongoDB增删改查

目录 NoSQL非关系型数据库关系型数据库&#xff08;RMDB&#xff09;介绍非关系型数据库&#xff08;NoSQL&#xff09;介绍Redis & MongoDB 在 Koa 中使用 Redis (了解)Redis 的安装和使用在 Koa 中连接 和 调用 Redis 在 Koa 中使用 MongoDBMongoDB 的安装MongoShell 操作…

day35KMP算法

1.什么是KMP算法 解决字符串匹配问题&#xff1b;看文本串是否出现过模式串&#xff1b; 文本串&#xff1a;aabaabaaf; 模式串&#xff1a;aabaaf&#xff1b; 暴力解法&#xff1a;两层for循环&#xff0c;时间复杂度&#xff1a;O(m*n) m n分别是长度&#xff1b; kmp解决&a…

HTML中的焦点管理

前言 焦点作为页面交互中的重要一环&#xff0c;涉及到的知识点也比较多&#xff0c;有必要做一个统一的总结。 HTML 中的可获取焦点的元素 具有 href 属性的 HTMLAnchorElement/HTMLAreaElement非禁用态的 HTMLInputElement/HTMLSelectElement/HTMLTextAreaElement/HTMLBut…

C++实现简单内存池

/写一个简单的内存池class Cgirl { public:int bh;//编号int xw;//胸围static char* m_pool; //内存池的初始地址//内存池初始化函数、static bool initpool() {cout << "调用初始化函数\n\n";m_pool (char*)malloc(18);//向堆内存空间申请18字节if (m_pool …

100天精通Golang(基础入门篇)——第17天:深入解析Go语言中的指针

&#x1f337; 博主 libin9iOak带您 Go to Golang Language.✨ &#x1f984; 个人主页——libin9iOak的博客&#x1f390; &#x1f433; 《面试题大全》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33a; &#x1f30a; 《I…

F#奇妙游(17):F#与真空一维平面大地抛石飞行力学

F#还能干点啥 距离上一次更新已经过去了很久&#xff08;40分钟之久&#xff01;&#xff09;&#xff0c;这段时间我在学习F#&#xff0c;并且在工作&#xff08;划掉&#xff0c;躺肥并没有工作要做&#xff09;中使用F#。 那干点啥呢&#xff1f;还是老本行吧&#xff0c;…