这是自己的关于map集合的相关操作的小研究,分享给大家。

主要代码内容包含以下:

1,map集合的遍历

2,根据key值获取value值

3,根据value值获取key值

4,返回最大value值对应的key值

5,获取最大key值,最小key值,最大value值,最小value值

上代码:

  1   @Test
public void bb1(){//测试代码
Integer value=0;
Map<Integer,Integer> map=new HashMap<Integer,Integer>();
map.put(1, 12);
map.put(2, 13);
map.put(4, 11);
map.put(7, 22);
map.put(3, 55); //map集合的遍历
Iterator<Integer> i = map.keySet().iterator(); while(i.hasNext()){
Integer next = i.next();
System.out.println("key2值:"+next+"----"+"value值:"+map.get(next));//key值是自然排序的
}
System.out.println("最大值Key值"+getMaxKey(map));
System.out.println("最小值Key值"+getMinKey(map));
System.out.println("最大值val值"+getMaxVal(map));
System.out.println("根据value值获取key值:"+getKeyByVal(map,55));
System.out.println("返回最大值value对应的key值:"+getKeyByMaxValue(map,value));
System.out.println("根据key值获取对应的value值:"+getValByKey(map,1)); } /**
* 根据key值获取value值
* @param map
* @param key
* @return
*/
public static Object getValByKey(Map<Integer,Integer> map,Integer key){
Integer value=0;
for(Integer getVal:map.values()){
if(getVal==map.get(key)){
value=getVal;
}
}
return value;
}
/**
* 求最大key值
* @param map
* @return
*/
public static Object getMaxKey(Map<Integer,Integer> map){
if(map==null){
return null;
}
Set<Integer> set=map.keySet();
Object[] obj = set.toArray();
Arrays.sort(obj);//sort升序排序
return map.get(obj[obj.length-1]);//获得最大key值对应的value值
// return obj[obj.length-1];
}
/**
* 获取最大value值
* @return
*/
public static Object getMaxVal(Map<Integer,Integer> map){
if(map==null){
return null;
}
Collection<Integer> val = map.values();
Object[] obj = val.toArray();
Arrays.sort(obj);
// return obj[0];//获取最小value
return obj[obj.length-1];//获取最大value
}
/**
* 返回最小的key值
* @param map
* @return
*/
public static Object getMinKey(Map<Integer,Integer> map){
if(map==null){
return null;
}
Set<Integer> set = map.keySet();
Object[] obj = set.toArray();
Arrays.sort(obj);
return obj[0]; }
/**
* 根据value值获取对应的key值
* @return
*/
public static String getKeyByVal(Map<Integer,Integer> map,Integer value){
Integer key=0;
for(Integer getKey:map.keySet()){
if(map.get(getKey)==value){
key=getKey;//这个key值最后一个满足条件的key值
} }
return "value值为:"+value+"对应的key值为:"+key;
}
/**
* 返回最大值对应的key值
* @param map
* @param value
* @return
*/
public static Integer getKeyByMaxValue(Map<Integer,Integer> map,Integer value){
Integer maxVal =(Integer) getMaxVal(map);
value=maxVal;
Integer key=0;
for(Integer getKey:map.keySet()){
if(map.get(getKey)==value){
key=getKey;
}
}
return key;
}

欢迎批评,交流和指正,谢谢!

Map集合中,关于取值和遍历的相关操作的更多相关文章

  1. 【js jQuery】map集合 循环迭代取值---以及 map、json对象、list、array循环迭代的方法和区别

    后台给前台传来一个map @ResponseBody @RequestMapping(value = "getSys") public Map<Long,String> ...

  2. C#中hashtable的赋值、取值、遍历、排序操作

    一,哈希表(Hashtable)简述 在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似key/value的键值对,其 ...

  3. 键盘录入一个文件夹路径,统计该文件夹(包含子文件夹)中每种类型的文件及个数,注意:用文件类型(后缀名,不包含.(点),如:"java","txt")作为key, 用个数作为value,放入到map集合中,遍历map集合

    package cn.it.zuoye5; import java.io.File;import java.util.HashMap;import java.util.Iterator;import ...

  4. Java——删除Map集合中key-value值

    通过迭代器删除Map集合中的key-value值 Iterator<String> iter = map.keySet().iterator(); while(iter.hasNext() ...

  5. js实现hashtable的赋值、取值、遍历

    哈希表(Hashtable)这个概率应该是#c里面的概念,用来赋值.取值.遍历.排序操作提高效率.想起这个东西其实使我们以前经常遇到这样的面试题,一个很大的数组可能有100000个,如何快速知道它里面 ...

  6. map集合修改其中元素 去除Map集合中所有具有相同值的元素 Properties长久保存的流操作 两种用map记录单词或字母个数的方法

    package com.swift.lianxi; import java.util.HashMap; import java.util.Iterator; import java.util.Map; ...

  7. 过滤掉map集合中key或value为空的值

    package cn.com.utils; import org.apache.commons.lang3.StringUtils; import java.util.Collection; impo ...

  8. Map集合中的同一键值key重复赋值

    前言: 验证:对Map集合中的同一键值key重复赋值? 结果:对Map集合中的同一键值key重复赋值会覆盖之前的结果. 验证如下: Map<String, Object> map = ne ...

  9. Map集合中value()方法与keySet()、entrySet()区别

    http://blog.csdn.net/liu826710/article/details/9001254 在Map集合中 values():方法是获取集合中的所有的值----没有键,没有对应关系, ...

随机推荐

  1. SpringBoot配置拦截器

    [配置步骤] 1.为类添加注解@Configuration,配置拦截器 2.继承WebMvcConfigurerAdapter类 3.重写addInterceptors方法,添加需要拦截的请求 @Co ...

  2. WebAPP移动前端性能优化规范和设计指导

  3. mysql8绿色免安装win64版本(自带heidisql.exe客户端)应该兼容老版第三方工具。

    https://pan.baidu.com/s/1cvQ4AJX6rmqSpMhBQTPz4Q 如果缺c库,自己去找下. 使用方法:先执行initdb.bat初始化数据 如果要安装为服务:执行inst ...

  4. 开源纯C#工控网关+组态软件(十)移植到.NET Core

    一.   引子 写这个开源系列已经十来篇了.自从十年前注册博客园以来,关注了张善友.老赵.xiaotie.深蓝色右手等一众大牛,也围观了逗比的吉日嘎啦.精密顽石等形形色色的园友.然而整整十年一篇文章都 ...

  5. ectouch 概述

    模块(The Model): 即M 主要包含那些用来操作数据库的函数 文件后缀一般是***Model.class.php 路径一般是../mobile/include/apps/default/mod ...

  6. 使用float属性的一些小技巧

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAPwAAACJCAIAAACHJsJCAAAKUUlEQVR4nO2dTY8cxRnHd73LLsusDd ...

  7. (六)SpringBoot2.0基础篇- Redis整合(JedisCluster集群连接)

    一.环境 Redis:4.0.9 SpringBoot:2.0.1 Redis安装:Linux(Redhat)安装Redis 二.SpringBoot整合Redis 1.项目基本搭建: 我们基于(五) ...

  8. Linux 普通用户之间免密登陆

    目的: 同台机器之间实现普通用户之间的免密登陆: NN01 的user1 免密登陆 user2 不同机器之间实现普通用户之间的免密登陆 :NN01 的user1 免密登陆 NN01 的user1 一. ...

  9. sql优化总结

    在项目前期目标是确保功能能够正常运行,但是随着时间的推移,数据的增加,逻辑的复杂,导致数据查询会越来越慢,这个时候我们首先想到的应该就是尽量优化sql. sql优化常见注意点: 1.对查询进行优化,应 ...

  10. 十七、Hadoop学记笔记————Hbase入门

    简而言之,Hbase就是一个建立在Hdfs文件系统上的数据库(mysql,orecle等),不同的是Hbase是针对列的数据库 Hbase和普通的关系型数据库区别如下: Hbase有一些基本的术语,主 ...