-
Data: 2012-10-14 03:05:10
Temat: Re: sortowanie
Od: bartekltg <b...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2012-10-14 02:18, M.M. pisze:
> W dniu niedziela, 14 października 2012 01:33:48 UTC+2 użytkownik bartekltg napisał:
>> Teoretycznie to ja rysuję drzewo i nie muszę tego
>> implementować;)
>> Sprzętowe sortowanie za pomocą pełnego drzewa decyzyjnego
>> dla 20 liczb? Jaja sobie robisz? ;) Oszczedza się kompa,
>> ale trzeba tone krzemu.
> Jak duze musi byc pelne drzewo decyzyjne? Poczatkowo mamy N! mozliwych
> permutacji. Pierwsza instrukcja IF powoduje ze mam pewnosc co do
> kolejnosci dwoch elementow. Jesli N==20, to po pierwszym IF nie
> wiemy nic o 18tu elementach. Daje to 18! ciagow. Pozostale dwa elementy
> moga byc wplecione w te 18 na 19*19 sposobow. 20! / ( 18! * 19^2 ) = 1.0526.
> Po pierwszym IFie ilosc permutacji spadla o okolo 5%. O ile spadnie z
> kazdym nastepnym ifem?
Każdy if to pojście w prawo lub w lewo w drzewie decyzyjny.
To jest drzewo binarne o 20! liściach. Czyli o wysokości
ceil[log_2 (20!)] = 62 (PK już o tym pisał).
To teraz wszystkie rozmiary w każdym kroku znasz.
Pamiętaj, że w różnych gałęziach 'te same' ify mogą
porównywać zupełnie inne obiekty. Zerknij na potworka
poniżej. A to tylko 3 elementy.
[pseudokod pod podpisem]
Za to ile by się uprościło dopuszczając swapa po
pierwszym porównaniu. Wtedy taki algorym rozgałęzia
się tylko po 'topologicznie różnych' wynikach
(oczywiste jest, że po 2 porównaniach możemy mieć
linię albo V). Nadal ich liczba rośnie jednak wykładniczo.
pzdr
bartekltg
a,b,c
if (a>b)
{
if (b>c)
{
return {a,b,c};
}
else //a,c>b
{
if (a>c)
{
return {a,c,b};
}else
{
return {c,a,b};
}
}
}
else //b>a
{
if (a>c)
{
return {b,a,c};
}
else //b,c>a
{
if (b>c)
{
return {b,c,a};
}else
{
return {c,b,a};
}
}
}
Następne wpisy z tego wątku
- 14.10.12 03:13 Edek Pienkowski
- 14.10.12 03:39 M.M.
- 14.10.12 03:46 M.M.
- 14.10.12 04:00 bartekltg
- 14.10.12 04:07 Edek Pienkowski
- 14.10.12 04:24 M.M.
- 14.10.12 04:32 M.M.
- 14.10.12 05:38 M.M.
- 14.10.12 08:10 kenobi
- 14.10.12 08:15 kenobi
- 14.10.12 09:29 kenobi
- 14.10.12 09:39 M.M.
- 14.10.12 09:56 kenobi
- 14.10.12 10:03 M.M.
- 14.10.12 10:13 kenobi
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