• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Olimpiada Informatyczna - prośba o rozwiązanie Różnorodności (nie kod, "sposób")

Object Storage Arubacloud
+1 głos
674 wizyt
pytanie zadane 19 stycznia 2018 w C i C++ przez yossarian22 Początkujący (340 p.)
edycja 19 stycznia 2018 przez yossarian22
Witam, czy jest ktoś w stanie opisać sposób rozwiązania, obserwacje itd, dla zadania Różnorodność z tegorocznej OI https://szkopul.edu.pl/problemset/problem/eHGwrk9xShVF-z_2f7K4Yyb_/statement/

Z góry dziękuję, pozdrawiam
komentarz 19 stycznia 2018 przez Przemysław Obywatel (1,510 p.)
Rozumiesz polecenie i nie wiesz jak je zaprogramować, czy nie rozumiesz polecenia?
komentarz 19 stycznia 2018 przez yossarian22 Początkujący (340 p.)
Rozumiem polecenie i nie wiem jak zaprogramować w najlepszej możliwej złożoności czasowej przy podanym zakresie pamięci.
1
komentarz 19 stycznia 2018 przez yossarian22 Początkujący (340 p.)
Na ten moment próbowałem dwóch sposobów: Lecenie "wężykiem" każdego kwadraciku, oraz lecenie "kolumnami". Żadne nie spełnia wymogów czasowych.

1 odpowiedź

–2 głosów
odpowiedź 19 stycznia 2018 przez Przemysław Obywatel (1,510 p.)
Cześć :)
Sprawa wygląda tak:

Masz tablicę n na m i w niej wycinek k na k. Obliczenie różnorodności konkretnego wycinka jest raczej proste: lecisz kolejno po jego wszystkich polach, i jeśli wartość tego pola jest różna od wszystkich poprzednich wartości w tym wycinku, to zwiększasz różnorodnośc o 1.

Ale jak wyznaczyć wycinek z największą różnorodnością?
Po pierwsze powinieneś najpierw przyjąć, że max_różnorodność = różnorodnośc_pierwszego_wycinka, a później dla każdego wycinka sprawdzać czy jego różnorodność jest większa niż max_różnorodność. Jeśli tak to max_różnorodność = różnorodność_tego_wycinka.

Ale jak przelecieć pętlą po WSZYSTKICH możliwych wycinkach?
Hmmm... wiem jak to zrobić, ale strasznie ciężko mi zebrać myśli, żeby ci to wytłumaczyć ;)
Pomyśl sam, jak masz jakiś pomysł to napisz i spróbujemy ;)

Podobne pytania

0 głosów
3 odpowiedzi 557 wizyt
0 głosów
1 odpowiedź 323 wizyt
pytanie zadane 30 kwietnia 2018 w Offtop przez Dorian Bajorek Dyskutant (7,920 p.)
0 głosów
1 odpowiedź 281 wizyt
pytanie zadane 12 listopada 2018 w C i C++ przez niezalogowany

92,555 zapytań

141,403 odpowiedzi

319,560 komentarzy

61,940 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...