AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Mal 2(langzahlen)???

Ein Thema von heiopei · begonnen am 12. Apr 2004 · letzter Beitrag vom 13. Apr 2004
Antwort Antwort
heiopei
(Gast)

n/a Beiträge
 
#1

Mal 2(langzahlen)???

  Alt 12. Apr 2004, 20:14
abend,
ich hab mir das grundgerüst für rechnen mit langen zahlen geschrieben(also langzahlarithmetik; die ziffern der zahlen werden in arrays gespeichert; +, -, div 2 und anzeigen kann ich bereits)
ich möchte nun eine solche zahl mit2 multiplizieren:

division durch 2 realisiere ich so:

Delphi-Quellcode:
...
type ziffern = array[0..100] of Word;
...

function durch2(zahl:ziffern): ziffern;
var
  hilf, uebertrag, i: integer;
begin
  for i := 100 to 0 do
  begin
    hilf := a[i] + (10 * uebertrag); //10 = die basis
    uebertrag := a[i] and 1;
    a[i] := hilf shr 1;
  end;
end;
wie kann ich nun die multiplikation mit 2 durchführen?
(ich weiss nur, das es mit shl durchgeführt werden muss!!!)

wer die funktion oben nich ganz versteht, dem kann ich auch noch ein bsp geben(bin jetz nur zu faul zu schreiben :-) )

danke für hilfe,
heiopei

[edit=sakura] [delphi]-Tags eingefügt. Mfg, sakura[/edit]
[edit=Admin]BBCodes aktiviert. :mrgreen: Mfg, Daniel[/edit]
  Mit Zitat antworten Zitat
Benutzerbild von Mirilin
Mirilin

Registriert seit: 21. Dez 2002
Ort: Lenzburg
861 Beiträge
 
Delphi 6 Professional
 
#2

Re: Mal 2(langzahlen)???

  Alt 12. Apr 2004, 20:50


Als Alternative :
Zahl * 2 = Zahl + Zahl


mfg Tobias
Tobias
Die Physik ist für die Physiker eigentlich viel zu schwer.
  Mit Zitat antworten Zitat
heiopei
(Gast)

n/a Beiträge
 
#3

Re: Mal 2(langzahlen)???

  Alt 13. Apr 2004, 13:50
hallo mirlin,
diese lösung hatte ich mir auch schon überlegt!!
aber es muss irgendwie auch mit bitweisem verschieben und übertrag gehn,
da soweit ich weiss, dies schneller geht.

es muss doch irgendeine umkehrfunktion führ die oben beschriebene division
durch 2 geben!!

danke für hilfe
heiopei
  Mit Zitat antworten Zitat
Chewie

Registriert seit: 10. Jun 2002
Ort: Deidesheim
2.886 Beiträge
 
Turbo Delphi für Win32
 
#4

Re: Mal 2(langzahlen)???

  Alt 13. Apr 2004, 13:52
Eine Verschiebung um 1 Bit nach rechts entspricht einer Multiplikation mit 2.
Martin Leim
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind
  Mit Zitat antworten Zitat
heiopei
(Gast)

n/a Beiträge
 
#5

Re: Mal 2(langzahlen)???

  Alt 13. Apr 2004, 13:56
hallo chewie,
ich weiss(geht mit shl 1)aber da is kein übertrag bei!!!

tschüss,
heiopei
  Mit Zitat antworten Zitat
Benutzerbild von atreju2oo0
atreju2oo0

Registriert seit: 5. Dez 2003
Ort: Berlin
289 Beiträge
 
Delphi 6 Enterprise
 
#6

Re: Mal 2(langzahlen)???

  Alt 13. Apr 2004, 14:33
Ich weiß ja nicht wozu du das brauchst, aber wenn Du wirklich mit "großen" Zahlen rechnen willst dann ist dein Ansatz
in my mind schlecht gewählt!
Du kannst ja am Ende nur mit 2 multiplizieren und dividieren! Wenn es mit jeder Zahl gehen soll, dann musst du die schriftliche multiplikation und Division nachbauen und das ganze als "TextFile" deklarieren!
Aber vielleicht reicht ja auch die 2... Mehr weiß der Rechner eh nicht...
Thomas
  Mit Zitat antworten Zitat
heiopei
(Gast)

n/a Beiträge
 
#7

Re: Mal 2(langzahlen)???

  Alt 13. Apr 2004, 14:40
hallo,
bis jetzt benötige ich nicht mehr als *2 und /2.
außerdem bin ich schon fast fertig mit durch mal rechnen
allgemein!!!
aber *2 muss irgendiwe schneller sein

tschüss
heiopei
  Mit Zitat antworten Zitat
Benutzerbild von atreju2oo0
atreju2oo0

Registriert seit: 5. Dez 2003
Ort: Berlin
289 Beiträge
 
Delphi 6 Enterprise
 
#8

Re: Mal 2(langzahlen)???

  Alt 13. Apr 2004, 14:51
Das ist natürlich noch besser...
Thomas
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:40 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz