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

Min w tablicy wielowymiarowej

0 głosów
1,167 wizyt
pytanie zadane 24 maja 2018 w Java przez Marius Nowicjusz (140 p.)

Witam.
Chciałbym stworzyć metodę do obliczenia wartości min w każdym wierszu tablicy wielowymiarowej. Poszczególne wartości tablicy mają być umieszczone w tablicy, którą metoda zwraca. Napisałem kod:

import java.util.Arrays;

public class minimum {

	public static void main(String[] args) {

		int[][] tab = { { 1, 3, 4 }, { 4, 5, 6, 8, 9 }, { 7, 8, 9 } };

		int[] minValue = minimum(tab);
		System.out.println(Arrays.toString(minValue));
	}

	static int[] minimum(int[][] tab) {

		int min = tab[0][0];

		for (int i = 1; i < tab.length; i++) {
			for (int j = 1; j <tab[i].length; j++) {
				if (tab[i][j] < min)
					min = tab[i][j];
			}

		}
		return min;

	}

}

Program nie kompiluje się, wskazany zostaje błąd przy zwracaniu wartości z metody. Jak błąd popełniłem?

1 odpowiedź

+1 głos
odpowiedź 24 maja 2018 przez xenonso Mądrala (5,160 p.)

Po pierwsze zmień nazwę metody minimum bo w tym momencie jest to konstruktor.

Po drugie metoda ta ma zwracać tablicę intów 

 static int[] minimum(int[][] tab) {

a zwracasz zwykłego inta

komentarz 24 maja 2018 przez xenonso Mądrala (5,160 p.)
Dodatkowo nazwy klas w Javie powinny zaczynać się z dużej litery
komentarz 24 maja 2018 przez Marius Nowicjusz (140 p.)

@xenonso,  Dziękuję za zainteresowanie tematem. Jakie rozwiązanie rekomendujesz? Możesz mi podesłać jakieś tytuły literatury opisujące to rozwiązanie?

komentarz 24 maja 2018 przez xenonso Mądrala (5,160 p.)
Raczej nie znajdę czegoś takiego. Mogę jednak podsunąć ci rozwiązanie. Stwórz czystą tablicę jednowymiarową, do której będziesz zapisywał wartości minimalne z każdego rzędu. Dodatkowo stwórz zmienną, do której będziesz przypisywał  tymczasowo wartość minimalną w wierszu.
komentarz 24 maja 2018 przez xenonso Mądrala (5,160 p.)

wyglądało by to mniej więcej tak

static int[] minimum(int[][] tab) {
 
        int[] min = new int[tab.length];
        int localMin = 0;
        for (int i = 0; i < tab.length; i++) {
            localMin = tab[i][0];
            min[i] = tab[i][0];
            
            for (int j = 0; j<tab[i].length; j++) {
                if (tab[i][j] < localMin) {
                    localMin = tab[i][j];
                    min[i] = localMin;
                }    
            }
        }
        return min;    
    }   

 

Podobne pytania

0 głosów
1 odpowiedź 212 wizyt
0 głosów
1 odpowiedź 1,410 wizyt
pytanie zadane 7 stycznia 2019 w PHP przez niezalogowany
0 głosów
1 odpowiedź 569 wizyt

93,667 zapytań

142,586 odpowiedzi

323,125 komentarzy

63,190 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

Twierdza Linux. Bezpieczeństwo dla dociekliwych

Aby uzyskać rabat -10%, użyjcie kodu pasja-linux, wpisując go w specjalne pole w koszyku.

...