-
Data: 2009-08-16 21:57:40
Temat: .Net Dictionary (System.Collections) problem z wyszukiwaniem...
Od: "Marcin Połeć" <u...@g...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Witam,
mam problem z wyszukiwaniem w słowniku. Gdy wyszukuję jednego klucza
wszystko jest ok, tzn. bardzo szybko. Problem pojawia się w momencie gdy
chcę sprawdzić powiedzmy milion kluczy. Mój program generuje najpierw listę
kombinacji liter a następnie sprawdza w słowniku które z tych kombinacji się
tam znajdują. Samo generowanie listy zabiera góra do 2-3 sekund, natomiast
sprawdzanie które z tych kombinacji są w słowniku - od 20s do kilku minut.
Kod wygląda tak:
bool Check(string słowo)
{
if(dictionary.contains(new KeyValuePair<string, bool>(słowo, false))
return true;
else
return false;
}
[...]
string ret = "";
foreach(string s in kombinacje)
{
if(Check)
ret += s+", ";
}
Próbowałem też dictionary.containsKey(słowo) ale jest jeszcze wolniejsze niż
z kvp.
Moje pytanie brzmi jak to przyspieszyć??? Zastanawiałem się nad
zrezygnowaniem z metody "na siłę" czyli sprawdzania wszystkich kombinacji i
zastąpieniu jej szukaniem wzorca klucza w słowniku, ale nie wiem czy takie
coś jest w ogóle możliwe w .net? Może coś z linqiem? Proszę o rady...
--
Wysłano z serwisu Usenet w portalu Gazeta.pl -> http://www.gazeta.pl/usenet/
Następne wpisy z tego wątku
- 16.08.09 22:06 Daniel Janus
- 17.08.09 02:51 Bartek Etenkowski
- 19.08.09 16:29 Marcin Połeć
- 19.08.09 16:31 Marcin Połeć
- 19.08.09 17:00 Daniel Janus
- 19.08.09 17:39 Marcin Kral
Najnowsze wątki z tej grupy
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
Najnowsze wątki
- 2024-05-26 O co chodzi?
- 2024-05-26 PJ autobus-tramwaj
- 2024-05-26 Renault Trafic i lampka z czerwonym STOP
- 2024-05-26 cena pięciocyfrowa
- 2024-05-26 Re: Jak dobra KE "okrada" złą Rosję "dla Ukrainy"
- 2024-05-25 supercap
- 2024-05-25 Sulzbach => Technischer Rollouter (d/m/w) <=
- 2024-05-25 Warszawa => Senior Account Manager <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Interactive/Experience Designer <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Warszawa => SAP WM Consultant / Execution <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Re: znów ten wrocław