Skocz do zawartości
Zamknięcie Forum PC LAB

Szanowny Użytkowniku,

Informujemy, że za 30 dni tj. 30 listopada 2024 r. serwis internetowy Forum PC LAB zostanie zamknięty.

Administrator Serwisu Forum PC LAB - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie: wypowiada całość usług Serwisu Forum PC LAB z zachowaniem miesięcznego okresu wypowiedzenia.

Administrator Serwisu Forum PC LAB informuje, że:

  1. Z dniem 29 listopada 2024 r. zakończy się świadczenie wszystkich usług Serwisu Forum PC LAB. Ważną przyczyną uzasadniającą wypowiedzenie jest zamknięcie Serwisu Forum PC LAB
  2. Dotychczas zamowione przez Użytkownika usługi Serwisu Forum PC LAB będą świadczone w okresie wypowiedzenia tj. do dnia 29 listopada 2024 r.
  3. Po ogłoszeniu zamknięcia Serwisu Forum od dnia 30 października 2024 r. zakładanie nowych kont w serwisie Forum PC LAB nie będzie możliwe
  4. Wraz z zamknięciem Serwisu Forum PC LAB, tj. dnia 29 listopada 2024 r. nie będzie już dostępny katalog treści Forum PC LAB. Do tego czasu Użytkownicy Forum PC LAB mają dostęp do swoich treści w zakładce "Profil", gdzie mają możliwość ich skopiowania lub archiwizowania w formie screenshotów.
  5. Administrator danych osobowych Użytkowników - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie zapewnia realizację praw podmiotów danych osobowych przez cały okres świadczenia usług Serwisu Forum PC LAB. Szczegółowe informacje znajdziesz w Polityce Prywatności

Administrator informuje, iż wraz z zamknięciem Serwisu Forum PC LAB, dane osobowe Użytkowników Serwisu Forum PC LAB zostaną trwale usunięte ze względu na brak podstawy ich dalszego przetwarzania. Proces trwałego usuwania danych z kopii zapasowych może przekroczyć termin zamknięcia Forum PC LAB o kilka miesięcy. Wyjątek może stanowić przetwarzanie danych użytkownika do czasu zakończenia toczących się postepowań.

Temat został przeniesiony do archiwum

Ten temat przebywa obecnie w archiwum. Dodawanie nowych odpowiedzi zostało zablokowane.

veelck

P3 || Cmax

Rekomendowane odpowiedzi

algorytm nastepujacy - tworze tablice 3-wymiarowa, gdzie jeden wymiar to ilosc zadan, a kolejne dwa to dlugosc zadan na 1 i na 2. procesorze. Pytanie - jak wybrac odpowiednio dlugosc zadan na 1. i 2. procku, zeby wynik wyszedl optymalny. Na pocztaku wzialem 1/3 sumy wszystkich zadan zaokraglona do gory - wygladalo ze dziala, do czasu jak przyszedl zestaw 1 7 7 1 1 i wyszlo szeregowanie:

p1 = 1 1 1

p2 = 0

p3 = 7 7

bo zadne zadanie 7 sie nie zmiescilo (1/3 sumy to 6)

to zmienilem na taki sposob, ze biore pod uwage jeszcze element maksymalny przy ustawianiu tablicy, czyli rozmiar jest 1/3 sumy zaokr. w gore albo wartosc maksymalna - no i wszystko byloby pieknie, poprzednia instancja rozwiazana prawidlowo, ale jak przyszla instancja postaci 1 4 5 6 8, to rozwiazanie bylo:

p1 = 5 1

p2 = 8

p3 = 6 4

bo 1/3 sumy wyniosla 8, tak jak dlugosc najdluzszego zadania, a optymalne rozwiazanie to np.

p1 = 5 4

p2 = 6 1

p3 = 8

 

czy ktos wie/ma pomysl jak to rozwiklac ? Prosze o w miare szybka odpowiedz...

tia

 

pozdrawiam

veelck

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

to jest tak, ze te 3 maszyny sa identyczne i zadania moga byc wykonywane dowolnie na kazdej z nich ?

 

jak tak, to problem jest takiego typu: podzielic zbior liczb na 3 podzbiory tak, zeby suma elementow w kazdym zbiorze byla zblizona do siebie

 

rozwiazania zachlanne beda w tym przypadku zwracac nieprawidlowe rozwiazanie; lepsze bedzie tworzenie drzewa mozliwych rozwiazan; albo wyznaczasz permutacje wstepna, a nastepnie sprawdzasz ktore z zadan mozna zamienic maszynami, zeby czas zakonczenia sie zmniejszyl

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

ok, kwestia wyboru algorytmu troche za pozno - mam juz za duzo kodu, to pierwsze, drugie - mialo byc wlasnie przez programowanie dynamiczne i na tablicach(wektorach) 'trojwymiarowych'

 

Ale nic to - problem mniej/wiecej rozwiazany, prowadzacy stwierdzil, ze wazne zeby dla wiekszosci przypadkow chodzilo, bo zawsze mozna jakis wredny przyklad dac (tzn. powiedzial to po tym, jak mu pokazalem ze algorytm ktory prezentuje wywala sie juz po wprowadzeniu np. pieciu zadan wszystkich o wartosci 3 ;) )

 

Wiem ze moglem to zrobic np. na drzewie i przechodzi je pozniej czyms w stylu Branch and Bound, ale mialo byc prog. dynamiczne, wiec... A rozwiazanie musi byc optymalne, wiec generowanie przyblizonych permutacji tez niewiele mi daje (mozna zapuscic jakis algorytm LSA, LPT albo cos w tym stylu, ale one nie daja optimum...)

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

  • Ostatnio przeglądający   0 użytkowników

    Brak zarejestrowanych użytkowników przeglądających tę stronę.

×
×
  • Dodaj nową pozycję...