我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java数据结构中图的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java数据结构中图的示例分析

这篇文章给大家分享的是有关Java数据结构中图的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

有向图

有向图的定义及相关术语

定义∶ 有向图是一副具有方向性的图,是由一组顶点和一组有方向的边组成的,每条方向的边都连着 一对有序的顶点。

出度∶ 由某个顶点指出的边的个数称为该顶点的出度。

入度: 指向某个顶点的边的个数称为该顶点的入度。

有向路径︰ 由一系列顶点组成,对于其中的每个顶点都存在一条有向边,从它指向序列中的下一个顶点。

有向环∶ —条至少含有一条边,且起点和终点相同的有向路径。

Java数据结构中图的示例分析

一副有向图中两个顶点v和w可能存在以下四种关系:

没有边相连;

⒉存在从v到w的边v—>w;

存在从w到v的边w—>V;

既存在w到v的边,也存在v到w的边,即双向连接;

理解有向图是一件比较简单的,但如果要通过眼睛看出复杂有向图中的路径就不是那么容易了。

Java数据结构中图的示例分析

有向图API设计

Java数据结构中图的示例分析

 在api中设计了一个反向图,其因为有向图的实现中,用adj方法获取出来的是由当前顶点v指向的其他顶点,如果能得到其反向图,就可以很容易得到指向v的其他顶点。

有向图的实现

// 有向图 public class Digraph {    // 记录顶点的数量         private final int V;     //记录边的数量    private int E;     //定义有向图的邻接表    private Queue <Integer>[] adj;     public Digraph (int v) {        //初始化顶点数量        this.V = v;        //初始化边的数量        this.E = 0;        //初始化邻接表        adj = new LinkedList[v];        //初始化邻接表的空队列        for (int i = 0; i < v; i++) {            adj[i] = new LinkedList<>();        }    }    public int V () {        return V;    }    public int E () {        return E;    }     //添加一条 v -> w的有向边    public void addEage (int v , int w) {        adj[v].add(w);        ++E;    }     //获取顶点v 指向的 所有顶点    public Queue<Integer> adj (int v) {        return adj[v];    }     //将有向图 反转 后返回    public Digraph reverse () {        //创建一个反向图        Digraph reverseDigraph = new Digraph(V);        //获取原来有向图的每个结点        for (int i = 0; i < V; i++) {            //获取每个结点 邻接表的所有结点            for (Integer w : adj[i]) {                //反转图记录下 w -> v                reverseDigraph.adj(w).add(i);            }        }        return reverseDigraph;    }}

拓扑排序

在现实生活中,我们经常会同一时间接到很多任务去完成,但是这些任务的完成是有先后次序的。以我们学习java学科为例,我们需要学习很多知识,但是这些知识在学习的过程中是需要按照先后次序来完成的。从java基础,到jsp/servlet,到ssm,到springboot等是个循序渐进且有依赖的过程。在学习jsp前要首先掌握java基础和html基础,学习ssm框架前要掌握jsp/servlet之类才行。

Java数据结构中图的示例分析

 为了简化问题,我们使用整数为顶点编号的标准模型来表示这个案例:

Java数据结构中图的示例分析

此时如果某个同学要学习这些课程,就需要指定出一个学习的方案,我们只需要对图中的顶点进行排序,让它转换为一个线性序列,就可以解决问题,这时就需要用到一种叫拓扑排序的算法。

拓扑排序图解

给定一副有向图,将所有的顶点排序,使得所有的有向边均从排在前面的元素指向排在后面的元素,此时就可以明确的表示出每个顶点的优先级。下列是一副拓扑排序后的示意图︰

Java数据结构中图的示例分析

检测有向图中的环

如果学习x课程前必须先学习y课程,学习y课程前必须先学习z课程,学习z课程前必须先学习x课程,那么一定是有问题了,我们就没有办法学习了,因为这三个条件没有办法同时满足。其实这三门课程x、y、z的条件组成了一个环︰

Java数据结构中图的示例分析

因此,如果我们要使用拓扑排序解决优先级问题,首先得保证图中没有环的存在。

检测有向环的API设计

Java数据结构中图的示例分析

检测有向环实现

在API中添加了onStack[]布尔数组,索引为图的顶点,当我们深度搜索时︰

在如果当前顶点正在搜索,则把对应的onStack数组中的值改为true,标识进栈;

如果当前顶点搜索完毕,则把对应的onStack数组中的值改为false,标识出栈;

如果即将要搜索某个顶点,但该顶点已经在栈中,则图中有环;

Java数据结构中图的示例分析

Java数据结构中图的示例分析

代码

 public class DirectedCycle {        private boolean[] marked;         private boolean hasCycle;         private boolean[] onStack;         public DirectedCycle (Digraph G) {        marked = new boolean[G.V()];        onStack = new boolean[G.V()];        hasCycle = false;        //因为不知道从那个点出发 可能存在环        //所以需要从所有的顶点都出发搜索 判断是否存在环        for (int i = 0; i < G.V(); i++) {            dfs(G,i);        }    }         private void dfs (Digraph G,int v) {        //标记顶点已经搜索过        marked[v] = true;        for (Integer adj : G.adj(v)) {            //判断v 是否已经在搜索的路径上了            if(marked[adj] && onStack[adj]) {                //存在环                hasCycle = true;            }else {                //采用回溯的思路                //让顶点入栈                onStack[adj] = true;                dfs(G,adj);                //回溯 顶点出栈                onStack[adj] = false;            }        }    }         public boolean hasCycle(){        return hasCycle;    } }

基于深度优先的顶点排序

如果要把图中的顶点生成线性序列其实是一件非常简单的事,之前我们学习并使用了多次深度优先搜索,我们会发现其实深度优先搜索有一个特点,那就是在一个连通子图上,每个顶点只会被搜索一次,如果我们能在深度优先搜索的基础上,添加一行代码,只需要将搜索的顶点放入到线性序列的数据结构中,我们就能完成这件事。

顶点排序API设计

Java数据结构中图的示例分析

顶点排序实现

在API的设计中,我们添加了一个栈reversePost用来存储顶点,当我们深度搜索图时,每搜索完毕一个顶点,把该顶点放入到reversePost中,这样就可以实现顶点排序。

Java数据结构中图的示例分析

Java数据结构中图的示例分析

Java数据结构中图的示例分析

Java数据结构中图的示例分析

代码:

 public class DepthFirstOrder {        private boolean[] marked;         private Stack<Integer> reversePost;     public DepthFirstOrder (Digraph G) {        marked = new boolean[G.V()];        reversePost = new Stack<>();        for (int i = 0; i < G.V(); i++) {            //如果顶点已经被搜索过则不用            if(!marked[i])                dfs(G,i);        }    }         private void dfs (Digraph G, int v) {        //标记顶点已经被搜索过        marked[v] =  true;        for (Integer w : G.adj(v)) {            if(!marked[w])                dfs(G,w);        }        //记录到线性序列中        reversePost.push(v);    }         private Stack<Integer> ReversePost() {        return reversePost;    }}

感谢各位的阅读!关于“Java数据结构中图的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java数据结构中图的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java数据结构中图的示例分析

这篇文章给大家分享的是有关Java数据结构中图的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。有向图有向图的定义及相关术语定义∶ 有向图是一副具有方向性的图,是由一组顶点和一组有方向的边组成的,每条方向的
2023-06-29

Java中数据结构的示例分析

这篇文章将为大家详细讲解有关Java中数据结构的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.1.1. 增量内存分配 ArrayList 、 HashMap 、 Vector 等类
2023-06-03

PHP数据结构中图遍历的示例分析

这篇文章将为大家详细讲解有关PHP数据结构中图遍历的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。图的遍历:深度优先与广度优先树的遍历演化到图的遍历还记得在树的学习中,我们讲到过先序、中序、后序以
2023-06-20

PHP数据结构之图存储结构的示例分析

这篇文章主要介绍PHP数据结构之图存储结构的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!图的存储结构图的概念介绍得差不多了,大家可以消化消化再继续学习后面的内容。如果没有什么问题的话,我们就继续学习接下来的
2023-06-20

java数据结构之树的示例分析

这篇文章主要介绍java数据结构之树的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!树定义和基本术语定义树(Tree)是n(n≥0)个结点的有限集T,并且当n>0时满足下列条件:(1)有且仅有一个特定的称为根
2023-05-30

Java数据结构与算法的示例分析

这篇文章给大家分享的是有关Java数据结构与算法的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。第1章 数据结构与算法基础概述1.1 数据结构和算法的重要性算法是程序的灵魂,优秀的程序可以在海量数据计算时
2023-06-29

Java数据结构之链表的示例分析

小编给大家分享一下Java数据结构之链表的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、链表的介绍什么是链表链表是一种物理存储单元上非连续、非顺序的存
2023-06-15

Java集合中基本数据结构的示例分析

这篇文章主要介绍Java集合中基本数据结构的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!集合中三大数据结构数组内存地址连续可以通过下标的成员访问,下标访问的性能高增删操作有较大的性能消耗(需要动态扩容)链表
2023-06-15

C++数据结构中list的示例分析

小编给大家分享一下C++数据结构中list的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!前言list相较于vector来说会显得复杂,它的好处是在任意位置插入,删除都是一个O(1)的时间复杂度。一、list的节点
2023-06-25

Java数据结构之红黑树的示例分析

小编给大家分享一下Java数据结构之红黑树的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、红黑树所处数据结构的位置:在JDK源码中, 有treeMap
2023-05-30

JDK 1.8中HashMap数据结构的示例分析

这篇文章给大家分享的是有关JDK 1.8中HashMap数据结构的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。概述JDK 1.8对HashMap361天恒平台制作,进行了比较大的优化,底层实现由之前的“
2023-06-04

Java中逻辑结构的示例分析

这篇文章主要介绍Java中逻辑结构的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Java中的逻辑结构逻辑结构 Java中的逻辑结构 顺序结构分支结构循环结构顺序结构顺序结构顾名思义,就是按照代码的顺序依次往
2023-06-14

python数据结构堆的示例分析

小编给大家分享一下python数据结构堆的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、说明堆是用数据结构来实现的一种算法:树,数组均可。堆本身是一棵完全二叉树。2、特点最大堆:所有父节点的值大于子节点的值最小
2023-06-15

Python Pandas数据结构的示例分析

这篇文章将为大家详细讲解有关Python Pandas数据结构的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1 Pandas介绍2008年WesMcKinney开发出的库专门用于数据挖掘的开源p
2023-06-29

Java数据结构图的领接矩阵举例分析

本篇内容介绍了“Java数据结构图的领接矩阵举例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.图的领接矩阵(Adjacency Ma
2023-06-21

C++ 数据结构中单链表的示例分析

小编给大家分享一下C++ 数据结构中单链表的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、链表是什么链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接依次实现的。由图,链
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录