Rekursiv - Problem :-)

Neue Frage »

Auf diesen Beitrag antworten »
Martin112 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 :-)
 
Auf diesen Beitrag antworten »
eulerscheZahl

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.
Auf diesen Beitrag antworten »
Martin112

Genau danach hatte ich gesucht, vielen Dank :-)
 
Neue Frage »
Antworten »


Verwandte Themen

Die Beliebtesten »
Die Größten »
Die Neuesten »