数据结构 - 相邻节点迭代器

news2024/11/13 19:26:54

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快!

文章目录

      • 引言
      • 一、相邻节点迭代器的基本概念
      • 二、相邻节点迭代器的设计
      • 三、相邻节点迭代器的实现
        • 1. 图节点类
        • 2. 相邻节点迭代器类
        • 3. 图类
        • 4. Java 示例代码
      • 四、总结

引言

在图论中,迭代器是一种常用的工具,用于遍历图中的节点或边。特别是当需要访问一个节点的所有相邻节点时,相邻节点迭代器提供了一种方便且灵活的方式。本文将深入探讨相邻节点迭代器的基本原理,并通过具体的Java代码详细说明如何实现高效的相邻节点迭代器。

一、相邻节点迭代器的基本概念

相邻节点迭代器是一种特殊的迭代器,用于遍历给定节点的所有相邻节点。在图中,每个节点可能与其他多个节点相连,这些相连的节点被称为该节点的相邻节点。相邻节点迭代器使得开发者可以轻松地访问这些相邻节点。

二、相邻节点迭代器的设计

为了设计相邻节点迭代器,我们需要考虑以下几个关键点:

  1. 迭代器接口:定义迭代器的基本行为,如是否有下一个节点、获取下一个节点等。
  2. 节点表示:如何表示图中的节点以及它们之间的连接。
  3. 迭代逻辑:如何遍历一个节点的所有相邻节点。
    在这里插入图片描述

三、相邻节点迭代器的实现

接下来,我们将通过一个示例来详细了解相邻节点迭代器的实现步骤。

1. 图节点类

定义图的节点类,包含一个用于存储相邻节点的列表:

import java.util.List;
import java.util.LinkedList;

public class GraphNode<T> {
    T data;
    List<GraphNode<T>> neighbors;

    public GraphNode(T data) {
        this.data = data;
        this.neighbors = new LinkedList<>();
    }

    public void addNeighbor(GraphNode<T> neighbor) {
        if (!neighbors.contains(neighbor)) {
            neighbors.add(neighbor);
        }
    }

    public void removeNeighbor(GraphNode<T> neighbor) {
        neighbors.remove(neighbor);
    }

    public List<GraphNode<T>> getNeighbors() {
        return neighbors;
    }
}
2. 相邻节点迭代器类

定义相邻节点迭代器类,实现迭代器接口:

import java.util.Iterator;
import java.util.List;

public class AdjacentNodesIterator<T> implements Iterator<GraphNode<T>> {
    private final List<GraphNode<T>> neighbors;
    private int currentIndex;

    public AdjacentNodesIterator(List<GraphNode<T>> neighbors) {
        this.neighbors = neighbors;
        this.currentIndex = 0;
    }

    @Override
    public boolean hasNext() {
        return currentIndex < neighbors.size();
    }

    @Override
    public GraphNode<T> next() {
        if (!hasNext()) {
            throw new IllegalStateException("No more elements to iterate over.");
        }
        return neighbors.get(currentIndex++);
    }
}
3. 图类

定义图类,实现节点的添加和获取相邻节点迭代器的方法:

import java.util.Map;
import java.util.HashMap;

public class Graph<T> {
    private Map<T, GraphNode<T>> nodes;

    public Graph() {
        nodes = new HashMap<>();
    }

    public void addNode(T data) {
        if (!nodes.containsKey(data)) {
            nodes.put(data, new GraphNode<>(data));
        }
    }

    public void addEdge(T data1, T data2) {
        GraphNode<T> node1 = nodes.get(data1);
        GraphNode<T> node2 = nodes.get(data2);

        if (node1 != null && node2 != null) {
            node1.addNeighbor(node2);
            node2.addNeighbor(node1);  // For undirected graph
        }
    }

    public AdjacentNodesIterator<T> getAdjacentNodesIterator(T data) {
        GraphNode<T> node = nodes.get(data);
        if (node == null) {
            throw new IllegalArgumentException("Node does not exist.");
        }
        return new AdjacentNodesIterator<>(node.getNeighbors());
    }
}
4. Java 示例代码

创建图并使用相邻节点迭代器:

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

        // 添加节点
        graph.addNode("A");
        graph.addNode("B");
        graph.addNode("C");
        graph.addNode("D");

        // 添加边
        graph.addEdge("A", "B");
        graph.addEdge("A", "C");
        graph.addEdge("B", "C");
        graph.addEdge("C", "D");

        // 获取相邻节点迭代器
        AdjacentNodesIterator<String> iterator = graph.getAdjacentNodesIterator("A");

        // 遍历相邻节点
        System.out.println("Adjacent nodes of 'A':");
        while (iterator.hasNext()) {
            GraphNode<String> adjacentNode = iterator.next();
            System.out.println(adjacentNode.data);
        }
    }
}

四、总结

相邻节点迭代器是一种非常实用的工具,尤其适用于需要访问图中节点的相邻节点的应用场景。在实际编程中,相邻节点迭代器可以用于实现各种算法,例如深度优先搜索(DFS)、广度优先搜索(BFS)等。


喜欢博主的同学,请给博主一丢丢打赏吧↓↓↓您的支持是我不断创作的最大动力哟!感谢您的支持哦😘😘😘
打赏下吧

💝💝💝如有需要请大家订阅我的专栏【数据结构与算法】哟!我会定期更新相关系列的文章
💝💝💝关注!关注!!请关注!!!请大家关注下博主,您的支持是我不断创作的最大动力!!!

数据结构与算法相关文章索引文章链接
数据结构与算法-插入排序数据结构与算法-插入排序
数据结构与算法-希尔排序数据结构与算法-希尔排序
数据结构与算法-归并排序数据结构与算法-归并排序
数据结构与算法-随机快速排序数据结构与算法-随机快速排序
数据结构与算法-双路快速排序数据结构与算法-双路快速排序
数据结构与算法-三路排序数据结构与算法-三路排序
数据结构与算法-关于堆的基本存储介绍数据结构与算法-关于堆的基本存储介绍
数据结构与算法-关于堆的基本排序介绍数据结构与算法-关于堆的基本排序介绍
数据结构与算法-索引堆及其优化数据结构与算法-索引堆及其优化
数据结构与算法-二分搜索树数据结构与算法-二分搜索树
数据结构与算法-二分搜索树链表节点的插入数据结构与算法-二分搜索树链表节点的插入
数据结构与算法-二分搜索树节点的查找数据结构与算法-二分搜索树节点的查找
数据结构与算法-二分搜索树遍历数据结构与算法-二分搜索树遍历
数据结构与算法-二分搜索树层序遍历数据结构与算法-二分搜索树层序遍历
数据结构与算法-二分搜索树节点删除历数据结构与算法-二分搜索树节点删除
数据结构 - 并查集基础数据结构 - 并查集基础
数据结构 - 并查集 size 的优化 数据结构 - 并查集 size 的优化
数据结构 - 并查集 rank 的优化 数据结构 - 并查集 rank 的优化
数据结构 - 并查集路径压缩 数据结构 - 并查集路径压缩
数据结构 - 图论基础 数据结构 - 图论基础

❤️❤️❤️觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄
💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍
🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

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

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

相关文章

nuxt3实战:完整的 nuxt3 + vue3 项目创建与useFetch请求封装

一. 安装 pnpm dlx nuxilatest init <project-name>// ornpx nuxilatest init <project-name>如遇到报错 手动安装&#xff1a; 浏览器访问报错https请求地址&#xff1a; 点击tar(项目初始文件的下载地址)对应地址,下载starter-3.tar.gz 包到本地 本地创建项…

【Android】使用网络技术——WebView的用法、http协议、OKHttp、解析XML、JSON格式数据笔记整理

WebView的用法 新建一个WebView项目 修改activity_main中的代码&#xff1a; <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"android:id"id/main"and…

STM32F1之SysTick系统定时器详细解析

目录 1. 简介 2. SysTick功能框图 3. SysTick寄存器 3.1 SysTick控制及状态寄存器 3.2 SysTick重装载数值寄存器 3.3 SysTick当前数值寄存器 3.4 SysTick校准数值寄存器 4. SysTick定时时间计算 5. SysTick寄存器结构体 6. 写一个us级延时函数 7. 写一个…

240806-RHEL 无法通过 ssh username@ip 远程连接,报错:Connection closed by ip port 22

A. 原因排查 遇到这个错误通常意味着 SSH 服务可能在目标主机上没有正常运行&#xff0c;或有防火墙/网络配置问题。以下是一些排查步骤&#xff1a; 检查 SSH 服务状态&#xff1a; 确认 SSH 服务是否正在目标主机上运行。 sudo systemctl status sshd重启 SSH 服务&#xff…

探索 Python 异步通信的奥秘:WebSockets 库的神奇之旅

文章目录 探索 Python 异步通信的奥秘&#xff1a;WebSockets 库的神奇之旅背景&#xff1a;为何选择 WebSockets&#xff1f;什么是 websockets 库&#xff1f;安装 websockets 库5个简单的库函数使用方法场景应用示例常见问题与解决方案总结 探索 Python 异步通信的奥秘&…

用Manim实现三维坐标系的绘制

1.ThreeDAxes 函数 ThreeDAxes是 Manim 中用于创建三维坐标系的类。在manim中常用的三位坐标绘制函数是&#xff1a; class ThreeDAxes(x_range(-6, 6, 1), y_range(-5, 5, 1), z_range(-4, 4, 1), x_length10.5, y_length10.5, z_length6.5, z_axis_configNone, z_normala…

数据仓库怎么建设?一文详解数仓的建设过程!

随着信息技术的飞速发展&#xff0c;企业不仅需要存储和管理海量数据&#xff0c;更迫切需要从这些数据中提取有价值的信息&#xff0c;以支持复杂的决策制定过程。数据仓库不仅是存储数据的场所&#xff0c;更是支持复杂查询、报告和数据分析的强有力工具&#xff0c;其建设已…

JavaScript异步简介|Promise快速入门

异步&#xff08;Asynchronous, async&#xff09;是与同步&#xff08;Synchronous, sync&#xff09;相对的概念。 异步 JavaScript 简介 异步编程技术使你的程序可以在执行一个可能长期运行的任务的同时继续对其他事件做出反应而不必等待任务完成。与此同时&#xff0c;你…

Linux工具|运维工具rename常用命令详解

&#x1f4eb; 作者简介&#xff1a;「六月暴雪飞梨花」&#xff0c;专注于研究Java&#xff0c;就职于科技型公司后端工程师 &#x1f3c6; 近期荣誉&#xff1a;华为云云享专家、阿里云专家博主、腾讯云优秀创作者、ACDU成员 &#x1f525; 三连支持&#xff1a;欢迎 ❤️关注…

【vulnhub】Wakanda :1靶机

靶机安装 下载地址&#xff1a;https://download.vulnhub.com/wakanda/wakanda-1.ova 运行环境&#xff1a;Virtual Box 信息收集 靶机IP扫描 netdiscover -i eth0 -r 192.168.7.0/24 端口扫描 nmap -A 192.168.7.243 -p- 80端口开启了http服务&#xff0c;在3333端口开启…

案例研究丨盛泰光电携手DataEase实现数据驱动智能制造

盛泰光电科技股份有限公司&#xff08;以下简称为“盛泰光电”&#xff09;是中国第一批摄像头模组制造企业。自成立至今&#xff0c;一直专注于手机摄像头模组的研发、制造、销售与服务&#xff0c;并向非手机包括笔记本、车载、医疗、AIoT等领域延伸&#xff0c;形成以手机摄…

PHP + Laravel + RabbitMQ + Redis 实现消息队列 (二) 消费队列在RabbitMQ和redis中的简单使用

最简单的队列功能 RabbitMQ和消息传递通常会使用一些术语&#xff1a; 生产者&#xff08;Producer&#xff09;意味着发送消息。一个发送消息的程序称为生产者。队列&#xff08;Queue&#xff09;尽管消息通过RabbitMQ和您的应用程序流动&#xff0c;但它们只能存储在队列中…

数据结构(01):数据结构概述(基本术语、逻辑结构和物理结构)

1、数据结构概述 (1)基本术语 A.数据元素 具有一定意义的基本单位。如人类的数据元素是人&#xff08;张三、李四等&#xff09;。 B.数据项 可以看作是数据元素的属性。如人的属性&#xff08;姓名、年龄、身高等&#xff09; C.数据对象 性质相同的数据元素的集合。如某一栋…

群聊的创建 表情包发送 图片发送

目录 群聊&#xff1a; ​编辑 表情包发送&#xff1a; 图片发送&#xff1a; 群聊&#xff1a; 1.群资料的表groupinformation 字段&#xff1a;GroupId 群id&#xff0c;GroupName 群名&#xff0c;CreatTime 创群时间&#xff0c;CreatUserId 创群的人&#xff0c;…

萤石云 ezuikit-js创建的播放器实例esc取消全屏后变黑屏

原因&#xff1a;上层页面重新设置了容器的宽高&#xff0c;导致uikit退出全屏时宽高计算异常 解决方法&#xff1a;实例初始化的时候会传入宽高width、height&#xff0c;播放器的画面尺寸是根据这两个参数设置的&#xff0c;然后退出全屏会回到这两个值

计算机的错误计算(五十五)

摘要 展示大数的余弦函数值的错误计算。 根据国际IEEE 754 标准[1]&#xff0c;包括余弦在内的三角函数的定义域是整个实数范围&#xff1a; 但是&#xff0c;实际情况怎样呢&#xff1f; 例1. 计算 . 在 Python下计算&#xff1a; x30**65 print(x) import math print(ma…

只强的Java学习之路8-7

一. 安装配置nodejs npm create vitelatest npm install vue-router npm install axios npm install element-plus --save npm run dev https://element-plus.org/zh-CN/#/zh-CN 新建项目&#xff1a; easy.vue <script setup></script><!--绑定数据-->…

在vue中页面使用了动态组件组件导致首次页面加载时子组件样式不显示,刷新后才正常

问题&#xff1a; 在vue中页面使用了动态组件组件导致首次页面加载时子组件样式不显示&#xff0c;刷新后才正常。 原因&#xff1a; 因为动态组件的延迟加载&#xff0c;如果使用了Vue的动态组件&#xff08;如<component :is"...">&#xff09;&#xff0c;…

【代码随想录】有序数组的平方

本博文为《代码随想录》的学习笔记&#xff0c;原文链接&#xff1a;代码随想录 题目 977. 有序数组的平方 给你一个按 非递减顺序 排序的整数数组 nums&#xff0c;返回 每个数字的平方 组成的新数组&#xff0c;要求也按 非递减顺序 排序。 示例 1&#xff1a; 输入&…

6种常用的AR跟踪方法

增强现实 (AR) 是一项令人着迷的技术&#xff0c;可将虚拟内容与现实世界无缝集成。实现这种无缝集成的关键组件之一是跟踪。各种类型的跟踪用于确定 AR 内容在环境中的准确位置和方向。本文介绍 AR 最常见的6种跟踪方法。 NSDT工具推荐&#xff1a; Three.js AI纹理开发包 - Y…