разделить коллекцию Java на вложенные коллекции на основе свойства объекта - PullRequest
6 голосов
/ 01 октября 2010

У меня есть список MyObjects ... MyObject {int id, String name}.Теперь я хочу разделить список на подсписки, которые имеют идентичные значения «id», может ли кто-нибудь предложить эффективный подход для этого.

Ответы [ 6 ]

10 голосов
/ 01 октября 2010
// create the thing to store the sub lists
Map<Integer, List<MyObject>> subs = new HashMap<Integer, List<MyObject>>();

// iterate through your objects
for(MyObject o : list){

    // fetch the list for this object's id
    List<MyObject> temp = subs.get(o.getId());

    if(temp == null){
        // if the list is null we haven't seen an
        // object with this id before, so create 
        // a new list
        temp = new ArrayList<MyObject>();

        // and add it to the map
        subs.put(o.getId(), temp);
    }

    // whether we got the list from the map
    // or made a new one we need to add our
    // object.
    temp.add(o);
}
8 голосов
/ 04 октября 2010

Использование Гуава :

ListMultimap<Integer, MyObject> myObjectsById = Multimaps.index(myObjects,
    new Function<MyObject, Integer>() {
      public Integer apply(MyObject myObject) {
        return myObject.id;
      }
    });
5 голосов
/ 27 мая 2017

Если вы используете JDK 1.8, вы можете использовать элегантное решение, такое как:

Map<Integer, List<MyObject>> myObjectsPerId =
    myObjects.stream().collect(Collectors.groupingBy(MyObject::getId));
2 голосов
/ 01 марта 2016

Использование JDK 1.8:

List<MyObject> objects= new ArrayList();
Map<Integer, List<MyObject>> obejctMap = new HashMap();
objects.stream().map(MyObject::getId).distinct().forEach(id -> obejctMap .put(id,
              objects.stream().filter(object -> id.equals(object.getId())).collect(Collectors.toList())));
2 голосов
/ 01 октября 2010

Переберите элементы, проверьте их значения id и поместите их в Hashtable с ключом id.Это O (N), которое так же эффективно, как и вы.

1 голос
/ 01 октября 2010
ArrayList<MyObject> list=new ArrayList<MyObject>();
//fill Objects..
HashMap<Integer,ArrayList<MyObject>> hash=new HashMap<Integer,ArrayList<MyObject>>();
for(MyObject elem:list)//iterate the list
{
ArrayList<MyObject> tmp=null; //temporary variable 
if((tmp=hash.get(elem.getId()))==null) // check if id already present in map
 {
  tmp=new ArrayList<MyObject>();   
  hash.put(elem.getId(),tmp); //if not put a new array list
 }
names.add(elem); //if present add the name to arraylist
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...