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

Min w tablicy wielowymiarowej

Cloud VPS
0 głosów
1,070 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ź 160 wizyt
0 głosów
1 odpowiedź 1,341 wizyt
pytanie zadane 7 stycznia 2019 w PHP przez niezalogowany
0 głosów
1 odpowiedź 500 wizyt

93,463 zapytań

142,459 odpowiedzi

322,727 komentarzy

62,840 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

Kursy INF.02 i INF.03
...