270 次查看
优先级队列是一种抽象数据类型,类似于队列或堆栈,其中每个元素都附加了一个优先级。优先级决定了元素从队列中出队的顺序,优先级较高的元素优先于优先级较低的元素出队。优先级队列可以使用不同的数据结构来实现,例如堆、数组或平衡树。最常用的实现是堆,它是一种基于二叉树的数据结构,每个节点的值大于或等于其子节点的值…… 阅读更多
173 次查看
Vector 类自 Java 1.2 版本以来一直是 Java 集合系统的一部分。Vector 有时被称为动态数组,因为与普通数组不同,它们可以扩展和收缩大小。Vector 是同步的,确保线程安全。虽然存在第三种方法,即使用 Apache Commons 反向迭代向量,但这需要下载额外的 jar 文件和包,大多数系统并不广泛支持。本质上,只有两种主要方法可以反向遍历向量元素。使用方法这里使用了两种方法…… 阅读更多
985 次查看
Java 中的反射 API 允许你使用其字符串名称动态调用任何方法。使用 java.lang.reflect API 时,即使在编译时无法访问类,你也可以按名称加载类,这要归功于反射强大的机制。它使你能够动态地使用反射调用任何方法,并使你能够检索类的所有方法,包括私有方法和公共方法。不熟悉 Java 的人可能会觉得这个想法很奇怪。在编译期间没有显式调用方法的代码,Java 可以在提供方法名称时执行方法…… 阅读更多
2K+ 次查看
借助 AbstractMap 类,Java 的 TreeMap 实现 Map 接口和 NavigableMap。此映射使用键的固有排序或在创建映射时提供的 Comparator 进行排序。在使用 Java 中的 TreeMap 时,目标是遍历其元素。但是,由于 TreeMap 不是集合,因此我们不能直接使用迭代器遍历它。使用方法要在 Java 中遍历 TreeMap,我们需要使用 TreeMap.entrySet() 方法。此函数返回 TreeMap 中保存的所有映射的集合视图 (Set<Map.Entry>)…… 阅读更多
316 次查看
Java HashMap 集合使用 (键,值) 对来存储数据。虽然它是非同步的,但它类似于 HashTable。因此,多个线程可以访问 HashMap 而不出现任何问题。尽管 HashMap 允许存储 null 键,但最多只能有一个 null 键对象和无限多个 null 值。关于映射的顺序,此类不作任何保证。键用于索引值。我们可以用 HashMap 存储唯一的键。如果我们尝试插入一个…… 阅读更多
Java HashSet 类在内部使用哈希表来实现 Set 接口,该接口使用 HashMap 实例。该类不保证项目会随着时间的推移而保持不变,因为哈希集中因素的迭代顺序并不总是保证的。此类中可以包含空元素。哈希函数为添加、删除、包含和大小等基本操作提供了高效的性能,假设它有效地将元素分布到桶中。HashSet 实现 Set 接口,它扩展了 AbstractSet。它使用哈希技术创建一个集合并保存…… 阅读更多
二维列表或列表的列表是一种数据结构,可用于以二维格式保存数据集合。在此列表的列表中,每个内部列表表示二维列表中的一行。例如,二维列表可以用于存储棋盘的数据,其中列表中的每个元素对应于棋盘上的一个方格。使用方法二维列表可以通过以下两种方法之一进行迭代:使用循环使用迭代器方法 1:使用循环有…… 阅读更多
1K+ 次查看
LinkedHashMap 的作用是保持元素添加的确切顺序。它阐明了按插入顺序访问元素的方法。除了基于键存储值外,LinkedHashMap 类还扩展了 HashMap 类的功能并实现了 Map 接口。它只容纳唯一的元素或映射。它使我们可以灵活地使用各种数据类型,例如文本、浮点数、整数等,来分配键和值。通过首先反转元素,我们可以更改链接哈希映射中元素的顺序。随后,我们可以…… 阅读更多
567 次查看
Trie 是一种类似于树的数据结构,用于存储和搜索动态字符串集。在处理键共享公共前缀(如字典词)的数据时,它非常有用。Trie 与其他检索数据结构不同,因为它具有高效的字符串操作和检索特性。在本文中,我们将学习如何在 Go 编程语言中实现 Trie 数据结构。解释Trie,也称为检索树,是一种树型数据结构,通常用于存储和管理字符串集合。它提供对…… 阅读更多
151 次查看
弗洛伊德三角形是以著名美国计算机科学家 Robert W. Floyd 命名的数字直角三角形图案。我们使用从 1 开始并在每一行增加 1 的自然数序列来构建这个三角形。在本文中,我们将用 Go 实现弗洛伊德三角形,这里的实现是指我们将创建弗洛伊德三角形然后打印它。解释弗洛伊德三角形与帕斯卡三角形非常相似,是一个直角排列的自然数。表中从左到右有数字的递增,每一行都从 1 开始…… 阅读更多