这是自己的关于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. JavaScript 很长很长的JS

    var BaiduUsers = [], WechatUsers = []; var User = function(id, name, phone, gender, age, salary) { t ...

  2. Install OpenCV on Ubuntu or Debian

    http://milq.github.io/install-OpenCV-ubuntu-debian/转注:就用第一个方法吧,第二个方法的那个sh文件执行失败,因为我价格kurento.org的源,在 ...

  3. ElasticSearch Index 速度优化 (官方翻译)

    使用Bulk请求进行Index Bulk请求将产生比单文档index请求有更好的性能.至于Bulk请求中文档数量的大小,建议使用单一节点单一分片进行测试,先试试看100个,然后200个,然后400这样 ...

  4. Flex 右键菜单控制

    //设置监控右键菜单项 private function setUserMenuItem():void{ var contextMenu:ContextMenu = new ContextMenu() ...

  5. mysql-高级操作

    主键冲突 主键冲突的时候,可以选择更新或者替换进行处理 更新 主键冲突,更新操作. Insert into 表名[(字段列表:包含主键)] values(值列表) on duplicate key u ...

  6. Flask快速入门

    flask快速入门 1.1.三种框架比较 Django: 重武器,内部包含了非常多组件:ORM.Form.ModelForm.缓存.Session.中间件.信号等 Flask:短小精悍,内部没有太多组 ...

  7. Linux环境安装配置JDK

    本文安装环境为Ubuntu14 64位,jdk版本为jdk1.6.0_38,安装文件名为jdk-6u38-linux-x64.bin(根据系统不同,下载不同的安装文件) 下载地址:http://www ...

  8. 夜神模拟器链接Android studoid

    在cmd 窗口输入:adb.exe connect 127.0.0.1:62001然后as就自动匹配了夜神经常忘记,特此提醒

  9. codeforces 983A Finite or not?

    题意: 判断一个分数在某一进制下是否为无限小数. 思路: 首先把这个分数约分,然后便是判断. 首先,一个分数是否为无限小数,与分子是无关的,只与分母有关. 然后,再来看看10进制的分数,可化为有限小数 ...

  10. SSM-SpringMVC-30:SpringMVC中InitBinder的骇客级优化

     ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 上篇博客利用initbinder做了局部的日期类型转换,但是兼容性不要,只支持yyyy-MM-dd这种,所以 ...