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

question-closed Pomysł na rozwiązanie zadania porachunki

Object Storage Arubacloud
0 głosów
174 wizyt
pytanie zadane 24 sierpnia 2020 w Algorytmy przez wojtek_suchy Mądrala (6,880 p.)
zamknięte 24 sierpnia 2020 przez wojtek_suchy

Mam takie zadanie:

Porachunki

Limit pamięci: 32 MB

Firma Bajtosoft zatrudnia image pracowników. Z powodu tajności projektów przez nią wykonywanych, nie wszyscy spośród nich się znają. Znają się ze sobą tylko ci, którzy zajmują się kolejnymi fazami pracy nad projektami.

Każdy projekt jest opracowywany w sposób sekwencyjny: najpierw pracownik nr image (szef zespołu) tworzy pierwszy szkic projektu, następnie przekazuje go pracownikowi nr image; ten po wykonaniu swojego zadania efekt pracy przekazuje pracownikowi nr image, i tak dalej, aż w końcu projekt trafia do pracownika nr image, który kończy pracę nad nim i przekazuje gotowy produkt szefowi (pracownikowi nr image).

Każdy pracownik ma w umowie zapisaną wysokość pensji, która mu przysługuje. Jednak firma nie zawsze dobrze wywiązuje się z umowy i choć zawsze wypłaca w sumie tyle pieniędzy swoim pracownikom, ile im się łącznie należy, to jednak nie zawsze wypłaca pieniądze właściwym osobom. Często zdarza się tak, że pewna osoba dostaje mniej pieniędzy, niż ma to zagwarantowane w umowie, zaś inna dostaje więcej, niż powinna.

Na szczęście pracownicy są uczciwi, dlatego umówili się, że po każdej wypłacie będą między sobą regulować wysokość otrzymanej pensji, tak aby ostatecznie każdy otrzymał dokładnie tyle, ile ma zagwarantowane w umowie.

Mają tylko jeden problem: przekazywać między sobą pieniądze mogą tylko ci pracownicy, którzy się znają, tzn. dla każdego image pracownik nr image może przekazać lub otrzymać pieniądze jedynie od pracowników nr image oraz image, pracownik nr image może dokonywać transakcji z pracownikami nr image oraz nr image, zaś pracownik nr image może dokonywać transakcji z pracownikami nr image oraz nr image.

Ponieważ każde takie wyrównywanie płac wymaga wielu transakcji, pracownicy Bajtosoftu poprosili Ciebie, niezależnego programistę, o napisanie programu, który po każdej wypłacie wyznaczy minimalną liczbę transakcji potrzebnych do wyrównania rachunków.

Zakładamy tutaj, że pracownicy wykorzystują w transakcjach tylko te sumy pieniędzy, które otrzymali w ramach danej wypłaty od firmy, oraz te, które otrzymali od innych pracowników w poprzednich transakcjach.

Wejście

W pierwszym wierszu standardowego wejścia znajduje się jedna liczba całkowita image (image) oznaczająca liczbę pracowników Bajtosoftu.

W każdym z następnych image wierszy znajdują się dwie liczby całkowite image oraz image (image), oddzielone pojedynczym odstępem i oznaczające pensję image-tego pracownika zagwarantowaną w umowie oraz ilość pieniędzy, którą otrzymał w rzeczywistości (wyrażone w bajtalarach). Możesz założyć, że image.

Możesz założyć, że w testach wartych łącznie image punktów zachodzi image, a w podzbiorze tychże testów wartym image punktów - dodatkowe ograniczenie: image.

Wyjście

Twój program powinien wypisać w pierwszym i jedynym wierszu standardowego wyjścia jedną liczbę całkowitą oznaczającą minimalną liczbę transakcji pomiędzy znającymi się pracownikami, która doprowadzi do stanu, w którym każdy pracownik otrzyma ostatecznie (po uwzględnieniu wszystkich transakcji) tyle pieniędzy, ile ma zagwarantowane w umowie.

W przypadku gdy żaden zestaw transakcji nie doprowadzi do takiego stanu, należy wypisać jedno słowo "NIE".

Przykład

Dla danych wejściowych:

4
10 13
5 4
5 6
8 5

poprawną odpowiedzią jest:

2

Wyjaśnienie do przykładu: Wyrównanie wszystkich pensji następuje w dwóch krokach: pracownik nr 3 przekazuje pracownikowi nr 2 jednego bajtalara, a pracownik nr 1 przekazuje pracownikowi nr 4 trzy bajtalary.

 

I Kompletnie nie mam pomysłu jak je rozwiązać, nie potrafię też znaleźć odpowiedzi w internecie, proszę o pomoc :)

komentarz zamknięcia: Trzeba od n odjąć maksymalną ilość powtórzeń sum prefiksowych

Podobne pytania

0 głosów
0 odpowiedzi 79 wizyt
0 głosów
1 odpowiedź 331 wizyt
0 głosów
1 odpowiedź 409 wizyt
pytanie zadane 19 lipca 2021 w Algorytmy przez wojtek_suchy Mądrala (6,880 p.)

92,632 zapytań

141,500 odpowiedzi

319,879 komentarzy

62,012 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!

...