-
Data: 2012-10-14 00:18:59
Temat: Re: sortowanie
Od: bartekltg <b...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2012-10-13 20:06, Edek Pienkowski pisze:
> Dnia Sat, 13 Oct 2012 10:50:01 -0700, kenobi napisal:
>
>>>
>>> No to już brzmi fajnie. A co to było to C, która wartość to ma być?
>>>
>>> Poza tym, czy swapów nie miało być jak najmniej?
>>>
>>>
>> C to dowolna wartosc z tablicy najlepiej gdyby to byla taka ktora podzieli
>> tablice na dwa zblizone wielkoscia kawalki, mozna wylosowac dowolna np ze
>> srodka przedzialu, wazne tylko by nie miec wielkiego pecha w wielce
>> dlugiej serii - bo wtedy stos sie wywali - ale taki pech jest malo
>> prawdopodobny
>
> Dowolna, czy się ją jakoś wybiera? Nie można robiąc te swapy na lewo
> i prawo policzyć sobie średniej przy okazji?
Oj, to wyższa filozofia;)
Można wybierać z prawej, z lewej, ze środka,
losowy element, medianę z końców i środka...
Jak ktoś chce, może zawsze brać element 7
(o ile tablica odpowiednio duża).
BTW, algorytm dzielenia proponowany przez fira nie jest najlepszy.
Raczej się robi to w ten sposób, że jedzie od początku w górę
jednym indeksem, aż napotka się element za duży. Potem od końca
w dół drugim indeksem, aż napotka się element za mały
(mniejszy od elementu dzielącego). następnie zamienia się
te elementy i wszytko powtarza, póki się indeksy nie spotkają.
Do testów (i by sprawdzić, ile pamiętam, zajmuję się zupelnie
innymi rzeczami) machnąłęm coś takiego:
void qsort(int * tabl,int first, int last)
{
if (last-first>1)
{
int piv = tabl[first];//element dzielący
int i=first; //elementow first i last+1
int j=last+1; //nigdy nie dotkniemy
do
{
do i++; while ((i<=last)&&(tabl[i]<piv));
do j--; while (tabl[j]>piv); // fajne*)
if (i<j) {std::swap(tabl[i],tabl[j])}
}while (i<j);
tabl[first]=tabl[j];
tabl[j]=piv;
qsort_insert(tabl, first, j-1);
qsort_insert(tabl, j+1, last);
}
}
Dzieki temu odpada jakaś polowa zapisów. W jednym ruchu swapa
_dwa_ elementy lądują po odpowiednich stronach podziału.
*) nie musimy sprawdzać zakresu, bo tab[first] go trzyma.
podobnie, jeśli nasza tablica jest podtablicą taką, że
tab[first-1] jest mniejsze, a tab[last+1] wieksze od kazdego
elementu naszej tablicy, nie musimy tego sprawdzać.
Zerknąłem do stla. Tam z tego korzystają i mają osobne
procedury dla prawego kranca, lewego, i podtablicy wewnetrz.
pzdr
bartekltg
Następne wpisy z tego wątku
- 14.10.12 00:21 M.M.
- 14.10.12 00:35 PK
- 14.10.12 00:41 bartekltg
- 14.10.12 00:49 bartekltg
- 14.10.12 00:51 PK
- 14.10.12 00:54 bartekltg
- 14.10.12 00:58 bartekltg
- 14.10.12 00:59 PK
- 14.10.12 01:03 bartekltg
- 14.10.12 01:08 bartekltg
- 14.10.12 01:19 Edek Pienkowski
- 14.10.12 01:16 PK
- 14.10.12 01:21 bartekltg
- 14.10.12 01:22 PK
- 14.10.12 01:25 M.M.
Najnowsze wątki z tej grupy
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
Najnowsze wątki
- 2025-07-02 Jaka ładowarka sieciowa do Iphona?
- 2025-07-02 ,,The Plot to Get RFK" (,,Spisek, by pozbyć się RFK")
- 2025-07-02 Rozkaz 17-2025: O Zaprzestaniu Zaciągania Kredytów
- 2025-07-02 Rozkaz 16-2025: 2025-06-19 Apelacja Do Wyroku Sądu Rej. w Sprawie IVRNs 295-23
- 2025-07-02 Rozkaz 17-2025: O Zaprzestaniu Zaciągania Kredytów
- 2025-07-02 Inżynierowie... inżynierzy...
- 2025-07-02 Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- 2025-07-02 Kto potrafi sprawdzić aku BMW 48V 10Ah Li-Ion do mini hybrydy, czy sprawny ?
- 2025-07-02 Warszawa => Senior IT Recruitment Consultant <=
- 2025-07-02 Gdańsk => Konsultant wdrożeniowy (systemy controlingowe) <=
- 2025-07-02 Warszawa => IT Hardware Specialist - Wsparcie i Konfiguracja <=
- 2025-07-02 Warszawa => Inżynier oprogramowania .Net <=
- 2025-07-02 Znaleziony
- 2025-07-02 Warszawa => Data Developer <=
- 2025-07-02 Kraków => Kotlin Developer <=