-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
atman.pl!.POSTED!not-for-mail
From: bartekltg <b...@g...com>
Newsgroups: pl.comp.programming
Subject: Re: liczby do zakresów
Date: Mon, 28 Oct 2013 23:22:55 +0100
Organization: ATMAN - ATM S.A.
Lines: 59
Message-ID: <l4mo50$c4j$1@node1.news.atman.pl>
References: <9...@g...com>
<op.w5n9f8zhjuu8ly@gi3nto>
NNTP-Posting-Host: 89-76-68-230.dynamic.chello.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: node1.news.atman.pl 1382999008 12435 89.76.68.230 (28 Oct 2013 22:23:28 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Mon, 28 Oct 2013 22:23:28 +0000 (UTC)
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:17.0) Gecko/20130801
Thunderbird/17.0.8
In-Reply-To: <op.w5n9f8zhjuu8ly@gi3nto>
Xref: news-archive.icm.edu.pl pl.comp.programming:204633
[ ukryj 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
- 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
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
Najnowsze wątki
- 2025-01-12 Jak na naszych oczach odradza się cenzura :-)
- 2025-01-11 Koszty prowadzenia firmy za granicą
- 2025-01-11 19 migrantów
- 2025-01-11 300km/h
- 2025-01-11 Kongres USA uchwalił "Prawo babci Pawlakowej" na MTK [Lex Gradma Pawlak]
- 2025-01-11 Riga => Specjalista ds. public relations <=
- 2025-01-11 Przestępca wyborczy Musk nadciąga nad Tuskistan?
- 2025-01-11 Białystok => Delphi Programmer <=
- 2025-01-09 Jaka nawigacja z asystentem zmiany pasa ruchu?
- 2025-01-10 Coś dusi.
- 2025-01-09 akumulator napięcie 12.0v
- 2025-01-10 Białystok => Architekt rozwiązań (doświadczenie w obszarze Java, A
- 2025-01-10 Warszawa => Software .Net Developer <=
- 2025-01-10 Białystok => Application Security Engineer <=
- 2025-01-10 Warszawa => System Architect (Java background) <=