简体   繁体   中英

Java: Data structure for sorting objects/maintaining a key in that order?

I want to maintain a collection of objects of type Odp. Odp implements Comparable. I need to be able to refer to an object in the collection with its integer name. This integer must correspond to its sort order (not insertion order). Each integer only applies to one Odp, and vice versa.

I have a function compareOdp(Odp o1, Odp o2) that returns a numeric value representing the similarity of the two arguments. I the Odp collection to be set up in such a way that it's easy to ask questions like "What is the closest Odp to foo in the collection?" or "Of these several collections of Odp objects, how close are they to each other?"

What is the best way to do this? TreeMap? HashBiMap?

Related Question:

Let's say I have the following set of objects: o1 , o2 , o3 contained in collection col . Their sort order is

o2
o3
o1

I want to ask col : "what is the nth object in the list?" From what I can see, SortedSet and TreeMap don't have a way to do this. I guess I could iterate over, but it feels like there should be an easier way.

If you are using Java 6, the NavigableSet API (implemented by TreeSet ) can help.

public static Odp nearest(Odp o, NavigableSet<? extends Odp> set) {
  Odp f = set.floor(o), c = set.ceiling(o);
  if (f == null)
    return c;
  if (c == null)
    return f;
  int df = compareOdp(o, f), dc = compareOdp(c, o);
  return (df <= dc) ? f : c;
}

Any implementation of SortedSet will keep the items in order, according to the Comparable interface. TreeSet is an implementation of SortedSet.

TreeMap is a build-in solution and as far as I've used it. I think it is pretty good.

I would use the lowly LinkedList . Then use Collections.binarySearch for searching the list. The binary search function will return you the insertion point in your linked list. To find which one is closest, simply use your compareOdp function with the item below and the item above in the linkedlist.

// What is the nth object in the list...

Object oneObject = TreeMap.get(nthKey);

Okay, so far / so good. If you do not care how they are contained in the Data Structure, you can use a ( might have to look it up but it would be called a ) HashMap == in which case there would be a key that you supply, which can easily be:

Object placement= HashMap.put(new Integer(++index),new Object(data));// see docs for exact

if placement is null, the map did not contain the object previously, used in conjuction with containsKey() exact management of data set is obtainable

Which will work find for get and put by ordered key, it's only that if you do toArray() you get a bizarre ordering that is only comprehensible to whomever wrote the HashMap implementation.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM