Rekursives Zählen einer Zahl

sngirl2010

Mitglied
Hallo liebe Forum-Mitglieder. Ich bin eine Informatikstudentin und wir haben gerade angefangen mit Java zu programmieren. Ich versuche gerade eine Übungsaufgabe zu lösen und stehe absolut auf dem Schlauch. Zuerst verstehe ich nicht wo der Unterschied ist zwischen rekursiv und nicht rekursiv? Und zweitens schaffe ich es gerade überhaupt nicht einen Plan zu entwickeln wie ich die Aufgabe lösen kann. Daher bitte und hoffe ich hier auf Hilfe.

Schreiben Sie eine rekursive Klassenmethode, die das Vorkommen einer Ziffer in einer Zahl zählt.
Z.B. sollte die Klassenmethode für die Zahl 1213414 und die Ziffer 1 das Ergebnis 3 liefern. Ihre
Klassenmethode muss die folgende Signatur haben:
public static int zaehleZifferInZahl(int ziffer, int zahl)
 

Enceladus271

Bekanntes Mitglied
Rekursiv heißt einfach nur das eine Methode sich selbst wieder aufruft. In deinem Fall Könntest du mit Hilfe des modulo Operators (%) die letzte Ziffer prüfen und mit Hilfe des div Operators (/) den restlichen Teil der Zahl erneut mit deiner Methode prüfen.
 

sngirl2010

Mitglied
Vielen Dank für die Antwort. Könntest du mir bitte etwas detaillierter die Vorgehensweise beschreiben? Ich kann jetzt deinen Gedankenansatz nicht folgen.
 

Tarrew

Top Contributor
Zum 1. Teil:
Du kannst die letzte Ziffer prüfen indem du die Zahl modulo (%) 10 nimmst. Das Ergebnis ist dann die letzte Ziffer.

Zum 2. Teil:
Wie schon erwähnt bedeutet Rekursion, dass du die eigene Methode innerhalb der Methode nochmal aufrufst. Nach dem Prüfen der letzten Ziffer, kannst du die Zahl dann durch 10 dividieren (das löscht effektiv die letzte Ziffer) und wiederum die letzte Zahl überprüfen. Das ganze geht dann so lange bis du alle Ziffern überprüfst hast.
 

sngirl2010

Mitglied
Das ist meine bisherige Lösung. Jedoch funktioniert diese nicht. Wo liegt den der Fehler:
public static void main(String[] args) {
System.out.println(zaehleZifferInZahl(1, 1123256));
}
//Aufgabe 1 Zählen und Ziffern
public static int zaehleZifferInZahl(int ziffer, int zahl){
int ergebnis = 0;
//int puffer = 0;
while (zahl > 0) {
zahl = zahl % 10;
if (zahl == ziffer){
ergebnis = +1;
}else {
zahl = zahl / 10;
}
}
return ergebnis;
}
 

sngirl2010

Mitglied
Ok, jetzt läufts. hier mein Code
System.out.println(zaehleZifferInZahl(1,1213414));
}
//Aufgabe 1 Zählen und Ziffern
public static int zaehleZifferInZahl(int ziffer, int zahl){
int ergebnis = 0;
int puffer = 0;
while (zahl > 0) {
puffer = zahl % 10;
if (puffer == ziffer){
ergebnis = ergebnis + 1;
}
zahl = zahl / 10;
}
return ergebnis;
}
 

Tarrew

Top Contributor
Code bitte in den Code Tags posten.

Gut, jetzt hast du schonmal eine iterative Lösung, aber du verwendest keine Rekursion. ;)
Hier mal ein Beispiel für eine Rekursion, die die Anzahl der Ziffer einer Zahl ausgibt:
Java:
    public static int anzahlZiffern(int i) {
        if (i / 10 == 0) {
            return 1;
        }
        return 1 + anzahlZiffern(i / 10);
    }
Wie du siehst wird die Funktion "anzahlZiffern" innerhalb der eigenen Funktion aufgerufen.

#Edit:
Bisschen OT, aber in der Schule bin ich an Rekursion auch immer verzweifelt. Hab echt lange gebraucht bis ich das mal halbwegs verstanden hatte.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Rekursives Programm zum Anzeigen von Primzahlen Java Basics - Anfänger-Themen 3
C Rekursives Backtracking beim Spiel Peg Java Basics - Anfänger-Themen 22
G Rekursives Programmieren --> harmonische Reihe Java Basics - Anfänger-Themen 3
S Rekursives Problem.... Java Basics - Anfänger-Themen 16
S Rekursives Durchlaufen eines Verzeichnisses - AccessDeniedException behandeln Java Basics - Anfänger-Themen 1
J Rekursives Parsen (ohne Reg Expressions) Java Basics - Anfänger-Themen 8
S Rekursives Umdrehen, Spiegeln. etc. von Strings Java Basics - Anfänger-Themen 3
I Rekursives Löschen in Binärem Suchbaum Java Basics - Anfänger-Themen 2
L rekursives spiel programmieren Java Basics - Anfänger-Themen 4
G Rekursives aufrufen führt zu StackOverflowError Panel durchl Java Basics - Anfänger-Themen 5
M Rekursives suchen im TreeMenu Java Basics - Anfänger-Themen 10
N Rekursives suchen in einer Liste Java Basics - Anfänger-Themen 8
G Primzahlentester als rekursives Programm! Java Basics - Anfänger-Themen 13
H Rekursives einlesen von Lokalen Ordner Java Basics - Anfänger-Themen 4
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
M Häufigkeit von Wörtern zählen Java Basics - Anfänger-Themen 6
Cassy3 Binäre Bäume Rekursiv durchlaufen und bestimmte Elemente Zählen Java Basics - Anfänger-Themen 6
D spezifische Knoten in einem Baum zählen Java Basics - Anfänger-Themen 9
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
S Java Methodenaufrufe zählen Java Basics - Anfänger-Themen 4
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
S Methoden Methodenaufruf rekursiv zählen Java Basics - Anfänger-Themen 4
J Methoden Positive Werte zählen Java Basics - Anfänger-Themen 3
H Buchstaben zählen Java Basics - Anfänger-Themen 9
Poppigescorn Häufigkeit einer zahl zählen Java Basics - Anfänger-Themen 5
HighLife Bestimmte Werte aus Array zählen Java Basics - Anfänger-Themen 15
O Attribute die Methoden zählen Java Basics - Anfänger-Themen 5
X Game of Life Nachbarn zählen Java Basics - Anfänger-Themen 20
F Java Programm, das kleine Buchstaben in einem String zählen soll und bei großen Buchstaben oder Sonderzeichen abbrechen soll. Java Basics - Anfänger-Themen 5
Z Satz aufteilen und die Wörter zählen (HashMap) Java Basics - Anfänger-Themen 15
S Binärbäume knoten zählen Java Basics - Anfänger-Themen 16
K Counts zählen Java Basics - Anfänger-Themen 23
Kirby.exe Anzahl vorkommender Elemente im Array zählen Java Basics - Anfänger-Themen 9
J Zeichen im String zählen Java Basics - Anfänger-Themen 3
G Binärer Suchbaum Knoten zählen Java Basics - Anfänger-Themen 1
N Zeichen in einem Textfeld zählen und hinterlegen Java Basics - Anfänger-Themen 6
E Knoten eines Baumes unter Bedinung zählen Java Basics - Anfänger-Themen 2
T x Schritte zählen Java Basics - Anfänger-Themen 18
P Schlüsselworte Zählen und Zuweisen von eingelesenen Zahlen Java Basics - Anfänger-Themen 1
A In einem String alle Eigennamen zählen Java Basics - Anfänger-Themen 6
L Baum Knoten zählen Java Basics - Anfänger-Themen 6
B Objekte zählen/ Vererbung/ Kopplung/ Interface/ Abstract Class Java Basics - Anfänger-Themen 5
S Zählen der Zeiger auf Objekte Java Basics - Anfänger-Themen 35
S Zeichen zählen kopierter Text Java Basics - Anfänger-Themen 6
B Array - die Häufigkeit der Zahl zählen Java Basics - Anfänger-Themen 9
L Vorherige Objekte zählen und ausgeben Java Basics - Anfänger-Themen 11
L Diphthonge zählen... Java Basics - Anfänger-Themen 5
O ELOPS Zählen Java Basics - Anfänger-Themen 1
X Quick Sort - Vergleichsoperationen zählen Java Basics - Anfänger-Themen 0
K alle Vorkommen einer bestimmten Ziffer in einer Zahl zählen Java Basics - Anfänger-Themen 2
B Collections Java Wörter in String zählen und geordnet ausgeben Java Basics - Anfänger-Themen 10
O Großbuchstaben im Satz zählen Java Basics - Anfänger-Themen 6
S zahl hoch und runter zählen per button Java Basics - Anfänger-Themen 25
N Zählen von Rationalen Werten eines Arrays Java Basics - Anfänger-Themen 10
Y for-Schleife zählen Java Basics - Anfänger-Themen 6
K Probleme mit Sortieren und dem Zählen Java Basics - Anfänger-Themen 13
S Vererbung Objekte von Ober - und Unterklassen zählen Java Basics - Anfänger-Themen 3
F SubString in String zählen Java Basics - Anfänger-Themen 3
C Im Array zählen und verändern Java Basics - Anfänger-Themen 5
O Zählen der while-Scheife Java Basics - Anfänger-Themen 3
P bytes aus einem InputStream zählen Java Basics - Anfänger-Themen 2
A Text teilen und Wörter zählen Java Basics - Anfänger-Themen 7
G Erste Schritte Einen Array absuchen und Buchstaben zählen Java Basics - Anfänger-Themen 17
F Problem mit Tabulatoren bei Zeilen zählen einer Textdatei Java Basics - Anfänger-Themen 17
F Textdatei einlesen und Zeilen zählen Java Basics - Anfänger-Themen 10
D Groß/KleinBuchstaben zählen Java Basics - Anfänger-Themen 21
D Buchstabe zählen/mappen Java Basics - Anfänger-Themen 3
S Anzahl unterschiedlicher Elemente zählen Java Basics - Anfänger-Themen 4
M Hilfe bei Zählen von Farben? Java Basics - Anfänger-Themen 7
R Input/Output Tastenschläge einer Taste zählen Java Basics - Anfänger-Themen 14
J Schleifendurchläufe zählen Java Basics - Anfänger-Themen 4
B Zweidimensionales Array Elemente jeder Spalte zählen Java Basics - Anfänger-Themen 9
E Methoden Methodenaufrufe zählen Java Basics - Anfänger-Themen 11
T Leerzeichen zählen mit Rekursion Java Basics - Anfänger-Themen 17
H Programm zum Zählen von Zeichen Java Basics - Anfänger-Themen 5
K Kommandozeile zählen Java Basics - Anfänger-Themen 5
J Bits zusammen zählen Java Basics - Anfänger-Themen 4
P Hashtabelle-Häufigkeit von String zählen Java Basics - Anfänger-Themen 2
J Array; Vorkommen zählen Java Basics - Anfänger-Themen 10
T durchlaufene while-Schleifen zählen Java Basics - Anfänger-Themen 3
P Replace zählen Java Basics - Anfänger-Themen 4
A Methoden Gedanken Anstöße zur Realisierung zweier Ideen (Grafisch Sekunden zählen und Frameaufteilung) Java Basics - Anfänger-Themen 18
E Zeichen von Kommandozeilenparameter zählen Java Basics - Anfänger-Themen 6
L Objekte zählen mehrerer Unterklassen Java Basics - Anfänger-Themen 3
J Buchstaben aus String einzeln Zählen Java Basics - Anfänger-Themen 12
J Enum zählen Java Basics - Anfänger-Themen 8
M Automatisch hoch zählen Java Basics - Anfänger-Themen 8
S Zählen Java Basics - Anfänger-Themen 9
V Arraylist: Zählen welcher String am Häufigsten vorkommt Java Basics - Anfänger-Themen 5
A Erste Schritte Datei einlesen und Buchstaben zählen Java Basics - Anfänger-Themen 13
M Von File lesen Buchstaben lesen und zählen - scheitert an der Eingabe Java Basics - Anfänger-Themen 4
B Zählen bestimmter Zeilen einer .txt Java Basics - Anfänger-Themen 7
A Satzeingabe - Vokale zählen Java Basics - Anfänger-Themen 5
G Gleiche Elemente in Feld zählen Java Basics - Anfänger-Themen 13
B Input/Output Wörter zählen & sortieren Java Basics - Anfänger-Themen 9
S Buchstaben/Wörter im String zählen Java Basics - Anfänger-Themen 6
K apache poi - Spalten zählen Java Basics - Anfänger-Themen 4
T Methodenaufrufe zählen Java Basics - Anfänger-Themen 24
L Array Sequent Zählen Java Basics - Anfänger-Themen 8
N Bestimmte Zeichen aus Strings zählen Java Basics - Anfänger-Themen 11

Ähnliche Java Themen

Neue Themen


Oben