Schriftliche Division zerlegen
-
Danke erstmal für die schnellen Antworten.
Noch ne Frage zu Dommels Vorschlag:
Wie kommt du auf diesen Teil?:
4 / 3 = 1 R 1
15 / 3 = 5 R 0
3 / 3 = 1 R 0
2 / 3 = 0 R 2Alles bis auf "15/3" kann ich mir ja noch erklären, aber wie kommst du auf die 15?
Danke im Voraus,
Prof. MAAD
-
Wegen Rest eins. Schau dir die schriftliche Division noch mal an.
-
Genau dass geht jedoch nicht, da der Divisor ja auch mal 100 Stellen haben kann und soviel kann kein INT-Wert aufnehmen. (Weshalb ich mir ja die Klasse schreibe).
Wo ist den das Problem. Nimm doch einfach ein Object deiner eigenen Klasse um das Ergebnis aufzunehmen. (Dafür ist die Klasse doch da!?)
-
MisterX schrieb:
Genau dass geht jedoch nicht, da der Divisor ja auch mal 100 Stellen haben kann und soviel kann kein INT-Wert aufnehmen. (Weshalb ich mir ja die Klasse schreibe).
Wo ist den das Problem. Nimm doch einfach ein Object deiner eigenen Klasse um das Ergebnis aufzunehmen. (Dafür ist die Klasse doch da!?)
Das Problem ist, dass auch bei der normalen schriftlichen Division geteilt werden muss. Und zwar mit Zahlen, die so groß wie der Divisor sind...
-
das beispiel war mist. durch ne einstellige zahl teilen geht halbschriftlich und ist nie ein problem.
ne 20-stellige durch ne 10-stellige, da wird es lustig.ich empfehle dem ungeübten algorithmiker die in anlehnung an die russische bauernmethode folgendes vorgehen:
123456789/12345
erstmal die 12345 so lange verdoppeln, bis sie größer als die hälfte von 123456789 ist. also wird aus 12345 mal schnell 101130240. dann subtrahieren, halbieren, subtrahieren, halbieren...sub: 123456789 -101130240 --------- 22326549 halb: 50565120 sub geht net. halb: 25282560 sub geht net. halb: 12641280 sub: 22326549 -12641280 -------- 9685269 und so weiter.
naja, und immer, wenn subtrahierne ging, fällt ne 1 raus, ansonsten ne 0 und die rausgefallenen ziffern sind das ergebnis in binärdarstellung.
wenn ich recht abschätze, braucht man O(n^2) schritte, also wird einem noch nicht mal übel, wenn man das verfahren mit dem aus der schule vergleicht.
-
hab deinen Algo mal mit der Hand ausprobiert:
52312 / 168 = 311 => 100110111
Allerdings bekomme ich folgendes:
100110111011001Also sozusagen 6 Stellen zuviel. Habs jetzt halt so lange gemacht, bis bei ner Subtraktion 0 rauskam...
Woran liegt das??PS: Wenn man die Zahl im Dezimalsystem dargestellt hat, ist diese Methode aber eigentlich nicht so toll, oder?? Man kann die Zahlen nämlich nicht durch 2 teilen, da man ja gerade ne Funktion zum Teilen schreiben will
Deine Methode ginge also nur, wenn man die Zahlen auch im Binärsystem hat...Edit: Kleiner Rechenfehler
Jetzt kann man die ersten 9 Stellen von vorne oder von hinten nehmen... Komisch...
-
Dommel schrieb:
@volkard:
hab deinen Algo mal mit der Hand ausprobiert:
52312 / 168 = 311 => 100110111Allerdings bekomme ich folgendes:
100110111011001Also sozusagen 6 Stellen zuviel. Habs jetzt halt so lange gemacht, bis bei ner Subtraktion 0 rauskam...
Woran liegt das??du sollst nicht so lange machen, bis ne 0 rauskommt, sondern nur so oft halbieren, wie du am anfang verdoppelt hast (oder isses einmal mehr)?
PS: Wenn man die Zahl im Dezimalsystem dargestellt hat, ist diese Methode aber eigentlich nicht so toll, oder?? Man kann die Zahlen nämlich nicht durch 2 teilen, da man ja gerade ne Funktion zum Teilen schreiben will
in der tat, da ist sie nicht so toll. um sie ans dezimalsystem anzupassen, muß man schon recht verzweifelt sein.
ich teile 52312 / 311.
311 plutimiziere ich solange mit 10 wie es geht, um noch <= 52312 zu bleiben. 3110 31100 nu substrahiere ich die 31100 so oft wie möglich. 52312 - 31100 = 21212 das war's schon. ich konnte [b]1[/b]-mal subtrahieren. nu substrahiere ich die 3110 so oft wie möglich. 21212 - 3110 = ... = 2552 das war's schon. ich konnte [b]6[/b]-mal subtrahieren. nu substrahiere ich die 311 so oft wie möglich. 2552 ... das war's schon. ich konnte [b]8[/b]-mal subtrahieren. ergebnius ist also [b]168[/b]
-
Dommel schrieb:
PS: Wenn man die Zahl im Dezimalsystem dargestellt hat, ist diese Methode aber eigentlich nicht so toll, oder?? Man kann die Zahlen nämlich nicht durch 2 teilen, da man ja gerade ne Funktion zum Teilen schreiben will
Hatten wir nicht weiter vorne festgestellt, daß Dividieren durch einstellige Zahlen eh einfach ist?
-
Hallo allemiteinander,
ich danke euch allen ganz doll für die Ideen.
Ich habe mich nun für Volkards letzte Methode entschieden und sie schon fertig implementiert.
Es funktioniert 1A. Vielen Dank für diese Idee.
Wer sich das Ergebnis, sprich meine fertige Klasse, mal angucken will:
http://profmaad.pr.funpic.de/onoint/Danke euch allen,
Prof. MAAD
-
Hab nochmal ne Verständnis-Frage:
Im Prinzip ist Volkards Algorithmus doch sehr ähnlich zum schriftlichen Dividieren, oder??
Der Unterschied besteht nur darin, dass er den Divisor "verschiebt", indem er mal 2 (bzw. 10 im Dezimalsystem) nimmt, und somit mit dem gesamten Dividenden rechnen kann. In der schriftlichen Division wirds halt nur anders herum gemacht, indem man den Divisor unverändert lässt und nur einen Teil des Dividenen betrachtet (ihn also teil, wenn man so will)...
-
volkard schrieb:
Dommel schrieb:
@volkard:
hab deinen Algo mal mit der Hand ausprobiert:
52312 / 168 = 311 => 100110111Allerdings bekomme ich folgendes:
100110111011001Also sozusagen 6 Stellen zuviel. Habs jetzt halt so lange gemacht, bis bei ner Subtraktion 0 rauskam...
Woran liegt das??du sollst nicht so lange machen, bis ne 0 rauskommt, sondern nur so oft halbieren, wie du am anfang verdoppelt hast (oder isses einmal mehr)?
PS: Wenn man die Zahl im Dezimalsystem dargestellt hat, ist diese Methode aber eigentlich nicht so toll, oder?? Man kann die Zahlen nämlich nicht durch 2 teilen, da man ja gerade ne Funktion zum Teilen schreiben will
in der tat, da ist sie nicht so toll. um sie ans dezimalsystem anzupassen, muß man schon recht verzweifelt sein.
ich teile 52312 / 311.
311 plutimiziere ich solange mit 10 wie es geht, um noch <= 52312 zu bleiben. 3110 31100 nu substrahiere ich die 31100 so oft wie möglich. 52312 - 31100 = 21212 das war's schon. ich konnte [b]1[/b]-mal subtrahieren. nu substrahiere ich die 3110 so oft wie möglich. 21212 - 3110 = ... = 2552 das war's schon. ich konnte [b]6[/b]-mal subtrahieren. nu substrahiere ich die 311 so oft wie möglich. 2552 ... das war's schon. ich konnte [b]8[/b]-mal subtrahieren. ergebnius ist also [b]168[/b]
Ich weiß, der Thread ist schon ein bisschen älter :D: , aber das ist genau das, was ich gesucht habe, vielen dank volkard ich war echt schon am verzweifeln