Registrierung Kalender Mitgliederliste Teammitglieder Suche Häufig gestellte Fragen Zur Startseite

Informatiker Board » Themengebiete » Praktische Informatik » Algorithmen » Größter gemeinsamer Teiler » Hallo Gast [Anmelden|Registrieren]
Letzter Beitrag | Erster ungelesener Beitrag Druckvorschau | An Freund senden | Thema zu Favoriten hinzufügen
Zum Ende der Seite springen Größter gemeinsamer Teiler
Beiträge zu diesem Thema Autor Datum
 Größter gemeinsamer Teiler Erstsemestler 16.01.2015 19:35
 RE: Größter gemeinsamer Teiler eulerscheZahl 16.01.2015 19:47
 RE: Größter gemeinsamer Teiler Erstsemestler 16.01.2015 19:53
 RE: Größter gemeinsamer Teiler eulerscheZahl 16.01.2015 19:56
 RE: Größter gemeinsamer Teiler Erstsemestler 16.01.2015 20:02
 RE: Größter gemeinsamer Teiler eulerscheZahl 16.01.2015 20:06
 RE: Größter gemeinsamer Teiler Erstsemestler 16.01.2015 20:07
 RE: Größter gemeinsamer Teiler eulerscheZahl 16.01.2015 20:10
 RE: Größter gemeinsamer Teiler Erstsemestler 16.01.2015 20:16
 RE: Größter gemeinsamer Teiler Karlito 16.01.2015 20:28
 RE: Größter gemeinsamer Teiler Erstsemestler 16.01.2015 23:30

Autor
Beitrag « Vorheriges Thema | Nächstes Thema »
Erstsemestler
unregistriert
Größter gemeinsamer Teiler Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Meine Frage:
Hey :-)

Hier noch ein weiteres Problem:

Ich möchte gerne ein Programm schreiben welches mir den größten gemeinsamen Teiler zweier Zahlen berechnet.

Vorgehensweise in der Mathematik:

Zahl 1 = 28;
Zahl 2 = 12;

ggT (28,12)

28-12 = 16
16-12 = 4
12-4 = 8
8-4 = 4
4-4 = 0

ggT somit = 4;

Meine Ideen:
Mein Code, der zwar für 24 und 9 (nur ein Beispiel) geht, aber für 124 und 12 nicht?

code:
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:

class Bruch
{
	public void ggT (int a, int b)
	{
		int c;
		for (int i=0; i<a;i++)
		{
			c = a-b;   // c = 48
			a=c; 		// a = 48
			if (a<b)		//Wenn c kleiner b , dann 	
			{
				int speicher;		 // 
				speicher = a;		// 48 in Speicher
				a = b;				// 4 auf a 
				b = speicher;		// 48 auf b
			}
			if (a==b)
			{
				System.out.println("Der ggT betraegt " + a);
				break; 
			}
		}
	}
}
			
		
	



Vielen Dank für Eure geschulten Blicke :-)
16.01.2015 19:35
eulerscheZahl eulerscheZahl ist männlich
Foren Gott


Dabei seit: 04.01.2013
Beiträge: 2.859

Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Die for-Schleife ist nicht nur sinnlos, sondern auch falsch. Schreibe an der Stelle while (true) und gut ist.
Statt der mehrfachen Subtraktion kannst du auch modulo verwenden, das spart Rechenzeit.

__________________
Syntax Highlighting fürs Board (Link)

Dieser Beitrag wurde 1 mal editiert, zum letzten Mal von eulerscheZahl: 16.01.2015 19:56.

16.01.2015 19:47 eulerscheZahl ist offline Beiträge von eulerscheZahl suchen Nehmen Sie eulerscheZahl in Ihre Freundesliste auf
Erstsemestler
unregistriert
Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

For for-Schleife?

Wie meinst du das genau?
16.01.2015 19:53
eulerscheZahl eulerscheZahl ist männlich
Foren Gott


Dabei seit: 04.01.2013
Beiträge: 2.859

Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Manchmal machen die Finger nicht das, was der Kopf will. Habe es editiert. Du sollst Zeile 7 austauschen.

__________________
Syntax Highlighting fürs Board (Link)
16.01.2015 19:56 eulerscheZahl ist offline Beiträge von eulerscheZahl suchen Nehmen Sie eulerscheZahl in Ihre Freundesliste auf
Erstsemestler
unregistriert
Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Hehe großes Grinsen Ich hatte das so interpretiert, dass ich zwei For-Schleifen im Programm habe :-)
16.01.2015 20:02
eulerscheZahl eulerscheZahl ist männlich
Foren Gott


Dabei seit: 04.01.2013
Beiträge: 2.859

Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Nein, nur meine Unfähigkeit im Umgang mit der Tastatur.

Hier noch die Kurzversion:
code:
1:
2:
3:
public static int ggT(int a, int b) {
	return b == 0 ? a : ggT(b, a % b);
}


__________________
Syntax Highlighting fürs Board (Link)
16.01.2015 20:06 eulerscheZahl ist offline Beiträge von eulerscheZahl suchen Nehmen Sie eulerscheZahl in Ihre Freundesliste auf
Erstsemestler
unregistriert
Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Da benötige ich noch ein Semester bis ich zu Beginn auf diese Kurzfassung komme :-)

Das ist der Bedingungsoperator, oder?
16.01.2015 20:07
eulerscheZahl eulerscheZahl ist männlich
Foren Gott


Dabei seit: 04.01.2013
Beiträge: 2.859

Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Keine Ahnung, ob das Ding einen speziellen Namen hat.
Ist eigentlich ganz einfach: Bedingung ? wenn true : wenn false;
Zum ? gehört auch immer ein :

__________________
Syntax Highlighting fürs Board (Link)
16.01.2015 20:10 eulerscheZahl ist offline Beiträge von eulerscheZahl suchen Nehmen Sie eulerscheZahl in Ihre Freundesliste auf
Erstsemestler
unregistriert
Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Hehe :-)


Dankeschön ;-)
16.01.2015 20:16
Karlito Karlito ist männlich
Kaiser


Dabei seit: 11.04.2011
Beiträge: 1.461

Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Klugscheißermodus an:
Der ?-:-Operator wird oft Bedingungsoperator genannt und ist der einzige ternäre Operator in Java.

Klugscheißermodus aus...

Augenzwinkern
16.01.2015 20:28 Karlito ist offline E-Mail an Karlito senden Beiträge von Karlito suchen Nehmen Sie Karlito in Ihre Freundesliste auf
Erstsemestler
unregistriert
Auf diesen Beitrag antworten Zitatantwort auf diesen Beitrag erstellen Diesen Beitrag editieren/löschen Diesen Beitrag einem Moderator melden       Zum Anfang der Seite springen

Hehe, danke für die Bestätigung :-) großes Grinsen
16.01.2015 23:30
Baumstruktur | Brettstruktur
Gehe zu:
Informatiker Board » Themengebiete » Praktische Informatik » Algorithmen » Größter gemeinsamer Teiler