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

Znajdowanie 4 elementów z listy o największej ilości punktów

Object Storage Arubacloud
0 głosów
251 wizyt
pytanie zadane 26 maja 2016 w Java przez martix3 Użytkownik (690 p.)

Witam!

Mam do napisania program, który automatycznie generuje finały i półfinały w zawodach przeciągania liny. Wyniki meczy są przechowywane na liście. Za każde zwycięstwo drużyna dostaje punkt(wrzucam algorytm). 

 public void tworzPolfinalLina() {
        int licznik = 0;
        for (int i = 0; i < listaDruzyn.size(); i++) {
            for (int j = 0; j < listaLina.size(); j++) {
                Druzyna a = listaDruzyn.get(i);
                Druzyna b = listaLina.get(j).getZwyciezca();
                if (a.equals(b) == true) {
                    licznik++;
                }

            }
            listaDruzyn.get(i).setPunkty(licznik);
            licznik = 0;

        }

Tyle mam. Tylko nie mogę wymyślić dobrego algorytmu, na znalezienie 4 drużyn z największą ilością punktów. No i co ewentualnie zrobić, gdy jest kilka drużyn o tej samej ilości punktów . Liczenie punktów z zawodów nic nie da bo wyniki są zapisywane w formacie 1, gdy drużyna wygra, 0 gdy przegra. Wtedy potrzebna by była jakaś dogrywka albo ewentualnie losowe wybranie drużyny, która przejdzie do półfinału. 

3 odpowiedzi

0 głosów
odpowiedź 26 maja 2016 przez KubenQPL Maniak (62,820 p.)
Poczytaj o algorytmie sortowania bąbelkowego, raczej najprostszy i najbardziej się nada :)
komentarz 5 października 2016 przez bartolinciu Dyskutant (7,580 p.)
Algorytm najprostszy, ale przydużej liczbie drużyn strasznie powolny, a poza tym bez sensu sortować całą tablicę dla czterech wartości.
0 głosów
odpowiedź 5 października 2016 przez bartolinciu Dyskutant (7,580 p.)
Ja bym znajdowanie 4 drużyn zrobił tak: 1. tworzę tablicę 4 drużyn 2. Znajduję drużynę z największą liczbą punktów i wrzucam ją do tablicy 3. Powtarzam krok 2 wykluczając z listy drużyny będące już w tablicy
0 głosów
odpowiedź 5 października 2016 przez webkam Bywalec (2,840 p.)
edycja 5 października 2016 przez webkam

Powiedzmy dla:

class Drozyna {
    Drozyna(String arg1, int arg2) {
    
        this.nazwa = arg1;
        this.punkty = arg2;
    }
    
    public int pobierzPunkty() {
        
        return this.punkty;
    }
    
    public String pobierzNazwe() {
        
        return this.nazwa;
    }
    
    private int punkty;
    private String nazwa;
}

Możesz to zrobić w taki sposób:

Arrays.asList(
        new Drozyna("DrozynaA", 4),
        new Drozyna("DrozynaB", 3),
        new Drozyna("DrozynaC", 1),
        new Drozyna("DrozynaD", 7),
        new Drozyna("DrozynaE", 12),
        new Drozyna("DrozynaF", 2)
).stream()
        .sorted(Comparator.comparing(Drozyna::pobierzPunkty).reversed())
        .limit(4)
        .forEach(x -> System.out.println(x.pobierzNazwe() + " " +x.pobierzPunkty()));

Druzyna*.... :P

Podobne pytania

0 głosów
3 odpowiedzi 797 wizyt
0 głosów
0 odpowiedzi 130 wizyt
pytanie zadane 27 sierpnia 2022 w Inne języki przez Sylbur81PL Nowicjusz (120 p.)
0 głosów
0 odpowiedzi 1,520 wizyt

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!

...