根据map中的某一key进行排序(快速排序实现)

/**
     * @author Gaoxl
     * 根据key值排序,要求key值能够转为Long类型(快速排序)
     * @param maps
     * @param key
     * @return
     */
    public static void sort(Map<String,Object>[] maps,String key,int start,int end){
        if(start < end){
            int mid = divide(maps,key,start,end);
            sort(maps,key,start,mid - 1);
            sort(maps,key,mid + 1,end);
        }
    }

   private static int divide(Map<String,Object>[] m ,String key, int start,int end){
       int mid = (start + end) / 2;
       Map<String,Object> midValue = m[mid];//取中间位置值作为排序关键
       m[mid] =  m[start];
       while(start < end){
          while(start < end && (Long)m[end].get(key) >= (Long)midValue.get(key)) --end;
          if(end > start){
              m[start] = m[end];
              ++ start;
          }
          while(start < end && (Long)m[start].get(key) <= (Long)midValue.get(key)) ++start;
          if(start < end){
              m[end] = m[start];
              -- end;
          }
       }
       m[start] = midValue;
       return start;
   }

原文地址:https://www.cnblogs.com/lin0/p/12009911.html

时间: 2024-10-03 15:14:01

根据map中的某一key进行排序(快速排序实现)的相关文章

Map集合按照value和key进行排序

最近由于特殊的业务需求,需要做相关数据排序,下面就贴出其中的将map集合中按照value或者key进行排序的代码,后面再具体详说. 1 /** 2 * map 集合排序 3 * @param map 4 * @return 5 */ 6 public static <K, V extends Comparable<? super V>> Map<K, V> sortMap(Map<K, V> map) 7 { 8 List<Map.Entry<K

【Java必修课】通过Value获取Map中的键值Key的四种方法

1 简介 我们都知道Map是存放键值对<Key,Value>的容器,知道了Key值,使用方法Map.get(key)能快速获取Value值.然而,有的时候我们需要反过来获取,知道Value值,求Key值. 本文将用实例介绍四种方法,通过传入Value值,获取得到Key值. 2 四种方法 2.1 循环法 循环法就是通过遍历Map里的Entry,一个个比较,把符合条件的找出来.会有三种情况: (1)找到一个值 (2)找到多个值 (3)找不到 具体代码如下: @Test public void lo

Python按照list中dict的某个key进行排序

在做项目的时候,遇到这样的数据:  "trends": [                {                     "name": "Rick Gates",                     "promoted_content": null,                     "query": "%22Rick+Gates%22",            

随机获取一个集合(List, Set)中的元素,随机获取一个Map中的key或value

利用Java提供的Random类.从List或Set中随机取出一个元素,从Map中随机获取一个key或value. 因为Set没有提供get(int index)方法,仅仅能先获取一个随机数后.利用一个计数器,对Set进行循环,当计数器等于随机数时返回当前元素,对于Map的处理也类似. 不知有没有更好的方法-- package com.xjj.util; import java.util.List; import java.util.Map; import java.util.Set; impo

Jackson中处理map中的null key 或者null value 及实体字段中的null value

1.map中有null key时的序列化  当有null key时,jackson序列化会报 Null key for a Map not allowed in JSON (use a converting NullKeySerializer?)  处理此异常有两种方式 1.需要自定义一个序列化null key的方法 2. map中直接remove null key 这里只讨论第一种: 处理方法为 mapper.getSerializerProvider().setNullKeySerializ

std::map中函数用法集合

1 STL的map表里有一个erase方法用来从一个map中删除掉指令的节点  2 eg:  3 map<string,string> mapTest;  4 typedef map<string,string>::iterator ITER;  5 ITER iter=mapTest.find(key);  6 mapTest.erase(iter);  7 像上面这样只是删除单个节点,map的形为不会出现任务问题,  8 但是当在一个循环里用的时候,往往会被误用,那是因为使用者

stl map中的lower_bound和 upper_bound

map中的lower_bound和upper_bound的意思其实很简单,就两句话: map::lower_bound(key):返回map中第一个大于或等于key的迭代器指针 map::upper_bound(key):返回map中第一个大于key的迭代器指针 所以,理解这两个函数请不要按照字面意义思考太复杂,因为仅仅是不小于(lower_bound)和大于(upper_bound)这么简单. 看两个msdn里的例子 1 // map_upper_bound.cpp 2 // compile

【java代码之美】---Java8 Map中的computeIfAbsent方法

Map中的computeIfAbsent方法 Map接口的实现类如HashMap,ConcurrentHashMap,HashTable等继承了此方法,通过此方法可以在特定需求下,让你的代码更加简洁. 一.案例说明 1.概述 在JAVA8的Map接口中,增加了一个方法computeIfAbsent,此方法签名如下: public V computeIfAbsent(K key, Function<? super K,? extends V> mappingFunction) 此方法首先判断缓存

获取map中的一个value值以及遍历map获得map里所有key、value的值

前言: 1.声明一个map: Map map = new HashMap();2.向map中放值,注意:map是key-value的形式存放的.如: map.put(”sa”,”dd”); 3.从map中取值:String str = map.get(”sa”).toString();结果是:str = ”dd”;4.遍历一个map,从中取得key 和valueMap map = new HashMap() ; Iterator it = map.entrySet().iterator() ;w