Avatar billede meltinis Nybegynder
01. marts 2008 - 17:11 Der er 7 kommentarer og
1 løsning

Find nærmeste eksisterende værdi i HashTable (eller lignende)

Jeg er i en situation hvor jeg skal gemme to sammenhængende værdier i fx. et HashTable og efterfølgende finde den ene ud fra den anden. Problemet er at den værdi jeg skal søge på ikke er kendt. Dvs. man skal finde den gemte værdi som er nærmest den søgte. I et eks. med tid og afstand: Jeg har gemt 12.2 km under 350 sek. og søger nu med værdien 12.1 km - her skal jeg så finde den nærmeste - 12.2 km og få værdien 350 sek. (jeg antager at der ligger mange flere sæt i det gemte)
Kan jeg gøre det? HasTable kan ikke da jeg der skal kende værdien 12.2 km præcist.
Avatar billede erikjacobsen Ekspert
01. marts 2008 - 17:20 #1
Hvor tit ændres tabellen? Det lyder som om du bare skal have det stående sorteret i et array, og så lave binær søgning. Så kommer du tæt på det sted værdien er (eller kunne være), og kan kigge dig omkring efter den nærmeste værdi.
Avatar billede arne_v Ekspert
01. marts 2008 - 17:23 #2
HashMap (og Hashtable) duer ikke til dette formål.

Du skal have noget sorteret.

Et hurtigt blik i java.util antyder at TreeMap måske kunne bruges.

floorKey og ceilingKey metoderne ser interessante ud.
Avatar billede meltinis Nybegynder
01. marts 2008 - 17:42 #3
TreeMap ser rigtig godt ud :) Men hvorfor kan jeg ikke bruge floorKey eller ceilingKey når jeg har import java.util.* - er der andre bib. jeg skal bruge?
Avatar billede arne_v Ekspert
01. marts 2008 - 19:14 #4
Hvilken Java version bruger du ? (de er vist nye i 1.6)
Avatar billede meltinis Nybegynder
02. marts 2008 - 02:25 #5
Min JDK var den som standard følger med i JBuilder - ikke lige den nyeste...åbenbart :) Tak for hjælpen - smid et svar...
Avatar billede arne_v Ekspert
02. marts 2008 - 03:16 #6
svar
Avatar billede meltinis Nybegynder
02. marts 2008 - 16:20 #7
Tak igen :)
Avatar billede jakoba Nybegynder
02. marts 2008 - 19:05 #8
apache has a class you could import
http://commons.apache.org/collections/api-2.1.1/org/apache/commons/collections/iterators/CollatingIterator.html
with it you can give an ordering relation for the elements in the original HashMap and treat the problem as a search in an ordered file
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester