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

Min w tablicy wielowymiarowej

Object Storage Arubacloud
0 głosów
779 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ź 116 wizyt
0 głosów
1 odpowiedź 1,066 wizyt
pytanie zadane 7 stycznia 2019 w PHP przez niezalogowany
0 głosów
1 odpowiedź 431 wizyt

92,572 zapytań

141,422 odpowiedzi

319,645 komentarzy

61,959 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!

...