首页 > 解决方案 > Java中是否有支持按(非唯一)值查找键的映射?

问题描述

我有一个设置,我的每个“人”都映射到一个特定的“房间”。

但是,多人可以映射到同一个房间。

如果看到现有人,则应将其房间更新为新值。

所以这是传统的用例Map<Person, Room>.put(Person, Room)

但是,查找总是会是“这个房间里有哪些人?” Set<People> get(Room q){}

我显然可以制作自己的数据结构或简单地迭代键值对;但是其中一个 Java 集合库是否具有良好的结构来支持我需要的引用完整性和查找?

标签: javaguava

解决方案


要回答你的具体问题,不,你不能用一种数据结构来做这一切。我会用

Map<Person,Room> personRoom;
SetMultimap<Room,Person> roomPeople;
void addPersonToRoom(Person p,Room r){
    Room currentRoom = personRoom.get(p);
    if (currentRoom != null)
        roomPeople.remove(currentRoom, p);
    personRoom.put(p,r);
    roomPeople.put(r,p);
}
Set<Person> getPeopleInRoom(Room r){
    return roomPeople.get(r);
}
Room getRoomForPerson(Person p){
    return personRoom.get(p);
}


推荐阅读