0

0

在Java TreeMap中查找元素的位置

王林

王林

发布时间:2023-08-24 17:05:02

|

1364人浏览过

|

来源于tutorialspoint

转载

在java treemap中查找元素的位置

在Java中,TreeMap类提供了一种以有序方式存储键值对的有效方法。有时候,我们可能需要找出TreeMap中特定元素的位置。在本文中,我们将探讨不同的方法来完成这个任务。我们将讨论语法、算法,并为每种方法提供可执行的代码示例。

语法

要在Java TreeMap中找到元素的位置,我们可以使用以下语法 -

int position = Collections.binarySearch(treeMap.values(), element);

语法解释

Collections.binarySearch()策略被用于对排序列表进行二分查找。在我们的情况下,我们将TreeMap的值传递给策略,并传递需要查找位置的组件。如果在列表中找到该组件,则策略返回组件的位置,否则返回一个负值。

方法一:使用binarySearch()

算法

  • 使用values()方法从TreeMap获取值。

    立即学习Java免费学习笔记(深入)”;

  • 使用Collections.binarySearch()对值进行二分搜索。

  • 将结果存储在名为position的变量中。

  • 如果位置大于或等于0,则找到该元素。否则,它不在TreeMap中。

示例

import java.util.Collections;
import java.util.TreeMap;

public class TreeMapPositionFinder {
   public static void main(String[] args) {
      TreeMap treeMap = new TreeMap<>();
      treeMap.put(1, "Apple");
      treeMap.put(2, "Banana");
      treeMap.put(3, "Orange");
      treeMap.put(4, "Mango");

      String element = "Banana";

      int position = Collections.binarySearch(treeMap.values(), element);

      if (position >= 0) {
         System.out.println("Element found at position: " + (position + 1));
      } else {
         System.out.println("Element not found in the TreeMap.");
      }
   }
}

解释

在这种方法中,我们创建一个TreeMap,并用一些键值对填充它。然后,我们定义要查找的元素,本例中为"Banana"。使用Collections.binarySearch()方法在TreeMap的值中搜索元素。如果找到该元素,我们通过将位置变量加1来打印其位置。否则,我们显示该元素未显示在TreeMap中。

方法2:使用TreeMap的keySet()和get()方法

算法

  • 使用keySet()方法从TreeMap获取keySet。

  • 迭代遍历键。

  • 检查与每个键相关联的值是否等于我们要查找的元素。

  • 如果找到匹配项,则将对应的键存储在名为position的变量中。

  • 如果position不为空,则表示元素已找到。否则,它不在TreeMap中存在。

    Gridster.js多列网格式拖动布局插件
    Gridster.js多列网格式拖动布局插件

    网页中拖动 DIV 是很常见的操作,今天就分享给大家一个 jQuery 多列网格拖动布局插件,和其它的插件不太一样的地方在于你处理拖放的元素支持不同大小,并且支持多列的网格布局,它们会自动的根据位置自己排序和调整。非常适合你开发具有创意的应用。这个插件可以帮助你将任何的 HTML 元素转换为网格组件

    下载

示例

import java.util.TreeMap;

public class TreeMapPositionFinder {
   public static void main(String[] args) {
      TreeMap treeMap = new TreeMap<>();
      treeMap.put(1, "Apple");
      treeMap.put(2, "Banana");
      treeMap.put(3, "Orange");
      treeMap.put(4, "Mango");

      String element = "Banana";
      Integer position = null;

      for (Integer key : treeMap.keySet()) {
         if (treeMap.get(key).equals(element)) {
            position = key;
            break;
         }
      }

      if (position != null) {
         System.out.println("Element found at position: " + position);
      } else {
         System.out.println("Element not found in the TreeMap.");
      }
   }
}

输出

Element found at position: 2

解释

在这种方法中,我们再次创建一个TreeMap并用键值对填充它。我们描述了我们需要找到的组件,这种情况下是"Banana"。然后,我们使用for-each循环遍历键,并检查与每个键相关联的值是否与我们要查找的元素匹配。如果找到匹配项,我们将相应的键存储在位置变量中。最后,我们检查位置是否无效,以确定元素是否显示在TreeMap中。

方法3:使用TreeMap的entrySet()和getValue()方法

算法

  • 使用entrySet()方法从TreeMap获取entrySet。

  • 遍历条目。

  • 检查每个条目的值是否等于我们要查找的元素。

  • 如果找到匹配项,则将对应的键存储在名为position的变量中。

  • 如果position不为空,则表示元素已找到。否则,它不在TreeMap中存在。

示例

import java.util.Map;
import java.util.TreeMap;

public class TreeMapPositionFinder {
   public static void main(String[] args) {
      TreeMap treeMap = new TreeMap<>();
      treeMap.put(1, "Apple");
      treeMap.put(2, "Banana");
      treeMap.put(3, "Orange");
      treeMap.put(4, "Mango");

      String element = "Banana";
      Integer position = null;

      for (Map.Entry entry : treeMap.entrySet()) {
         if (entry.getValue().equals(element)) {
            position = entry.getKey();
            break;
         }
      }

      if (position != null) {
         System.out.println("Element found at position: " + position);
      } else {
         System.out.println("Element not found in the TreeMap.");
      }
   }
}

输出

Element found at position: 2

解释

与第二种方法类似,我们创建一个TreeMap,填充它,并描述我们需要发现的组件。然后,我们使用for-each循环强调TreeMap的条目,并检查每个条目的值是否与组件匹配。如果找到匹配项,我们将相应的键存储在position变量中。最后,我们检查position是否无效,以确定组件是否显示在TreeMap中。

方法4:使用TreeMap的values()方法和indexOf()

算法

  • 使用values()方法从TreeMap获取值。

    立即学习Java免费学习笔记(深入)”;

  • 使用indexOf()方法查找元素的索引。

  • 如果索引大于或等于0,则表示元素已找到。否则,它不在TreeMap中。

示例

import java.util.ArrayList;
import java.util.TreeMap;

public class TreeMapPositionFinder {
   public static void main(String[] args) {
      TreeMap treeMap = new TreeMap<>();
      treeMap.put(1, "Apple");
      treeMap.put(2, "Banana");
      treeMap.put(3, "Orange");
      treeMap.put(4, "Mango");

      String element = "Mango";

      ArrayList values = new ArrayList<>(treeMap.values());
      int position = values.indexOf(element);

      if (position >= 0) {
         System.out.println("Element found at position: " + (position + 1));
      } else {
         System.out.println("Element not found in the TreeMap.");
      }
   }
}

输出

Element found at position: 4

解释

在这种方法中,我们首先创建一个TreeMap并填充它。我们描述了我们需要发现的组件,这里是“Banana”。然后,我们使用values()方法创建一个包含TreeMap值的ArrayList。我们使用indexOf()方法在ArrayList中找到组件的索引。如果索引大于或等于0,我们打印出组件的位置。否则,我们指示该元素未显示在TreeMap中。

结论

在本文中,我们探讨了在Java TreeMap中查找元素位置的不同方法。我们研究了语言结构、计算,并为每种方法提供了可执行的代码示例。根据您的特定需求和偏好,您可以选择最适合您需求的方法。Java中的TreeMap课程提供了一种强大而高效的方式来存储和操作排序数据,使您能够轻松执行各种操作。

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

833

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

738

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

734

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号