-
Data: 2013-10-28 23:22:55
Temat: Re: liczby do zakresów
Od: bartekltg <b...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2013-10-28 17:01, Piotr pisze:
> W dniu 28.10.2013 o 16:51 <d...@g...com> pisze:
>
>> Cześć
>> Czy istnieje jakiś sprawny algorytm, który pozwoliłby zastąpić taki
>> lub podobny ciąg liczb:
>> 1,2,3,4,6,7,8,14,15,16,190,191,192,300 w takie coś:
>> 1-4,6-8,14-16,190-192,300
>>
>> ??
>
> w kółko
> wczytaj liczbę
> jeśli jest o 1 większa od poprzedniej
> poszerz ostatni zakres
> w przeciwnym wypadku
> utwórz nowy zakres
Zakładając, że ciąg jest posortowany.
Jeśli nie jest, mamy O(n log(n))
Ale nie bójmy się, akademicka (akademikowa) teoretyczność*)
idzie z pomocą.
Weźmy strukturę/algorytm find-union.
Zbiory (te z f-u) wzbogaćmy informacją o najmniejszym i największym
elemencie (aktualizowana O(1)). Trzeba to
Teraz już prosto. Na początek koszyczek zbiorów pusty.
while wejście niepuste
odczytaj nową liczbę -> x
if (!(find(x)))
nowy_zbiór(x)
if (find(x-1)) union(x,x-1)
if (find(x+1)) union(x,x+1)
Na koniec, przechodząc wszystkie zbiory dostajemy, również
nieposortowany, zestaw przedziałów.
Złożoność O ( dziwna_funkcja(n) * n )
zaś dziwna funkcja (Ackermana) rośnie bardzo powoli,
wolniej niż logarytm iterowany (ile razy trzeba zlogarytmować
liczbę, by dostać <1).
*) obstawiam, że sortowanie i tak może wygrać dla ludzkich
zbiorów danych.
:)
pzdr
bartekltg
Następne wpisy z tego wątku
- 28.10.13 23:38 A.L.
- 29.10.13 00:17 bartekltg
- 29.10.13 08:07 Adam Wysocki
- 29.10.13 14:41 firr
- 29.10.13 23:03 Wojciech Muła
- 30.10.13 08:10 Wielebny
Najnowsze wątki z tej grupy
- Nowa ustawa o ochronie praw autorskich - opis problemu i szkic ustawy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- 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
Najnowsze wątki
- 2025-03-20 Re: Dlaczego tak odstają od Tesli?
- 2025-03-19 Brak ograniczeń dla chińskiego kapitału - wam nie do rządu, tylko na zmywak do chińskiej knajpy!!!
- 2025-03-19 Wietnam wykłada 500M$ i chce zbudować fabrykę za 50G$
- 2025-03-19 szal-Unia == federacja policyjna
- 2025-03-19 Polsza == państwo policyjne
- 2025-03-19 Grzegorz Płaczek o programie szczepień dzieci. ,,Stworzono eldorado dla firm farmaceutycznych"
- 2025-03-19 Wietnam wykłada 500M$ i chce zbudować fabrykę za 50G$
- 2025-03-19 Gemini
- 2025-03-19 Mokry sen Zenka :)
- 2025-03-19 Re: Dlaczego tak odstają od Tesli?
- 2025-03-19 Czy grupa p.s.prawo przetrwa najbliższe wybory (prezydenta)?
- 2025-03-19 Warszawa => Frontend Developer (obszar Angular13+) <=
- 2025-03-19 Czy "niedopuszczony pełnomocnik" jest w prawie się na to skarżyć jak "świadek" zmarła bez zostawienia mu takiej instrukcji?
- 2025-03-19 Kraków => Business Development Manager - Network and Network Security
- 2025-03-19 Ostrów Świętokrzy => Node.js / Fullstack Developer <=