-
Data: 2012-10-14 02:29:17
Temat: Re: sortowanie
Od: Edek Pienkowski <e...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Dnia Sun, 14 Oct 2012 00:18:59 +0200, bartekltg napisal:
> 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.
Mi raczej chodziło o generalnie możliwość policzenia
średniej z dowolnych obiektów mających "strict weak ordering".
I fir przestał mnie uczyć quick-sorta :)
Trochę za późno dla mnie na czytanie kodu, może jutro ;)
--
Edek
Następne wpisy z tego wątku
- 14.10.12 02:29 bartekltg
- 14.10.12 02:43 Edek Pienkowski
- 14.10.12 02:43 bartekltg
- 14.10.12 03:05 bartekltg
- 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
Najnowsze wątki z tej grupy
- Xiaomi [Chiny - przyp. JMJ] produkuje w całkowitych ciemnościach i bez ludzi
- Prezydent SZAP/USONA Trump ułaskawił prezydenta Hondurasu Hernandeza skazanego na 45 lat więzienia
- Rosjanie chwalą się prototypem komputera kwantowego. "Najważniejszy projekt naukowy Rosji"
- A Szwajcarzy kombinują tak: FinalSpark grows human neurons from stem cells and connects them to electrode arrays
- Re: Najgorszy język programowania
- NOWY: 2025-09-29 Alg., Strukt. Danych i Tech. Prog. - komentarz.pdf
- Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- Błąd w Sofcie Powodem Wymiany 3 Duńskich Fregat Typu Iver Huitfeldt
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- 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
Najnowsze wątki
- 2026-01-19 Katowice => Solution Architect (Workday) - Legal Systems <=
- 2026-01-18 off-grid
- 2026-01-18 Co grozi Żurkowi za jego działania polityczne?
- 2026-01-17 To się NIE DZIEJE
- 2026-01-17 Czy to się kwalifikuje pod jakiś paragraf?
- 2026-01-17 Piaseczno cd 2
- 2026-01-17 Chlapacze do OPLA ale GUMOWE
- 2026-01-17 Toyota dba o Niemców.
- 2026-01-17 Wrocław => Junior Konsultant wdrożeniowy ERP <=
- 2026-01-17 Zlacze w mikrofonie z lat 80-tych
- 2026-01-17 Warszawa => Inżynier Systemów i Sieci <=
- 2026-01-17 Czy Trenerzy AI już kogoś pozwali za "zatrute ciastka"?
- 2026-01-17 Poznań => Konsultant SAP HCM <=
- 2026-01-17 Niestabilny materiał wybuchowy W AKCJI
- 2026-01-17 Myślenice => Junior SAP CO Consultant <=




Fakturzystka, fakturzysta