Informatiker Board (http://www.informatikerboard.de/board/index.php)
- Themengebiete (http://www.informatikerboard.de/board/board.php?boardid=1)
-- Sonstige Fragen (http://www.informatikerboard.de/board/board.php?boardid=25)
--- Rekursiv - Problem :-) (http://www.informatikerboard.de/board/thread.php?threadid=2366)


Geschrieben von Martin112 am 30.06.2015 um 01:06:

  Rekursiv - Problem :-)

Meine Frage:
Hallo :-)

Ich habe jetzt zum Spaß eine rekursive Funktion geschrieben und möchte, dass bei der Zahl 10 der Zähler um eins erhöht wird (sinnlos ich weiß :-))

Allerdings bekomme ich immer den zu Beginn initialisierten Wert zurück.

Meine Ideen:
code:
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:

package javazaehle9en;

public class JavaZaehle9en 
{
    public static void main(String[] args) 
    {
        System.out.println(zaehle8en(15));
    }

    public static int zaehle8en (int zahl)
    {
        int counter = 0;
        if (zahl == 10) 
        {
            ++ counter;
        }
        return zahl>0?zaehle8en(zahl-1):counter; 
    }
}



Vielen Dank für Eure Hilfe :-)



Geschrieben von eulerscheZahl am 30.06.2015 um 15:13:

 

Hattest du dir sowas vorgestellt?
code:
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
public static int zaehle8en(int zahl) {
	if (zahl <= 0) {
		return 0;
	}
	int counter = 0;
	if (zahl == 10) {
		++counter;
	}
	return zaehle8en(zahl - 1) + counter;
}

Du setzt in jedem rekursiven Aufruf den counter auf 0 und gibst nur für zahl==1 counter zurück (den du davor wieder auf 0 gesetzt hast).

Ach ja: der Name der Funktion passt überhaupt nicht zu dem, was sie tut.



Geschrieben von Martin112 am 30.06.2015 um 17:46:

 

Genau danach hatte ich gesucht, vielen Dank :-)


Forensoftware: Burning Board, entwickelt von WoltLab GmbH