AGB  ·  Datenschutz  ·  Impressum  







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

Rechenaufgabe

Ein Thema von TheCatcher · begonnen am 13. Jul 2006 · letzter Beitrag vom 17. Jul 2006
Antwort Antwort
Seite 1 von 2  1 2      
TheCatcher

Registriert seit: 28. Mär 2006
30 Beiträge
 
Delphi 5 Standard
 
#1

Rechenaufgabe

  Alt 13. Jul 2006, 10:32
Ich habe eine rechenaufgabe deren Ergebnis auch mal Minus sein kann ergo -5484 -
Gibt es eine eifnach möglichkeite diese - dennoch NICHT anzuzeigen?
Oder bleibt mir da nichts anderes übrig als mit POS() etc zu arbeiten?
Gruss TheCatcher
  Mit Zitat antworten Zitat
Hulig4n

Registriert seit: 16. Jan 2006
15 Beiträge
 
#2

Re: Rechenaufgabe

  Alt 13. Jul 2006, 10:34
Benuzte Abs(-3) um das wert positiv zu machen.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#3

Re: Rechenaufgabe

  Alt 13. Jul 2006, 10:39
Aber mit ein bissl Nachdenken hätte man auch selber auf eine Lösung kommen können ... entweder unter MATH in der OH suchen, oder

if x < 0 then x := -x; PS: ABS macht intern nichts anderes

Code:
function abs(x: TYP): TYP;
  begin
    [b]if x < 0 then
      result := -x[/b]
    else
      result := x;
  end;
$2B or not $2B
  Mit Zitat antworten Zitat
TheCatcher

Registriert seit: 28. Mär 2006
30 Beiträge
 
Delphi 5 Standard
 
#4

Re: Rechenaufgabe

  Alt 13. Jul 2006, 10:43
Danke ABS war genau das geniale!


Versproche: ich werde die OH mehr betätigen nur weis ich meist nie wonach ich suchen soll und dann ist das Forum doch einfacher!
Gruss TheCatcher
  Mit Zitat antworten Zitat
Amateurprofi

Registriert seit: 17. Nov 2005
Ort: Hamburg
1.077 Beiträge
 
Delphi XE2 Professional
 
#5

Re: Rechenaufgabe

  Alt 17. Jul 2006, 03:31
Zitat von himitsu:
PS: ABS macht intern nichts anderes

Code:
function abs(x: TYP): TYP;
  begin
    [b]if x < 0 then
      result := -x[/b]
    else
      result := x;
  end;
@himitsu:
so ganz stimmt das nicht.
bei mir wird z.B. a:=Abs(a); so umgesetzt

bei Integerwerten
Delphi-Quellcode:
mov eax,[adresse a]
cdq // wenn a negativ dann sind in edx alle Bits=1, sonst alle=0
xor eax,edx
sub eax,edx
mov [adresse a], eax
bei realwerten, z.B. extended
Delphi-Quellcode:
fld tbyte ptr [adresse a]
fabs // setzt das Vorzeichenbit = 0
fstp tbyte ptr [adresses a]
Tja, warum schreibe ich das?!
weil ich gerade gestern das vermeintliche Problem hatte, daß ABS einen negativen Integerwert nicht in einen positiven Wert umwandelte.
Wenn nämlich eine Variable des Typs Integer ihren kleinstmöglichen Wert hat, also -2147483648 oder $8000000 dann gibt es keine korrespondierende positive Zahl und Abs() verändert den Wert nicht, er bleibt also negativ.
Hat ein bischen gedauert, bis ich begriffen hatte wo mein Denkfehler lag.
Bei eingeschalteter Überlaufprüfung gibts dann übrigens eine Fehlermeldung....
Gruß, Klaus
Die Titanic wurde von Profis gebaut,
die Arche Noah von einem Amateur.
... Und dieser Beitrag vom Amateurprofi....
  Mit Zitat antworten Zitat
alienous

Registriert seit: 27. Jan 2006
94 Beiträge
 
#6

Re: Rechenaufgabe

  Alt 17. Jul 2006, 12:09
hm, nur so ne frage, wenn man -5212 in 5212 umwandeln will, wieso multipliziert man dann nich einfach mit x *(-1)

das ganze noch in ne ifabfrage, ob der wert unter 0 ist, und fertig isses doch oder nich?
  Mit Zitat antworten Zitat
pacman1986

Registriert seit: 11. Feb 2005
Ort: Kirchhain
498 Beiträge
 
Delphi 2005 Personal
 
#7

Re: Rechenaufgabe

  Alt 17. Jul 2006, 12:35
Zitat von himitsu:
if x < 0 then x := -x;
genau das hat himitsu auch gesagt .
Christian N.
Designed to make a difference

najjaronline.de
  Mit Zitat antworten Zitat
Amateurprofi

Registriert seit: 17. Nov 2005
Ort: Hamburg
1.077 Beiträge
 
Delphi XE2 Professional
 
#8

Re: Rechenaufgabe

  Alt 17. Jul 2006, 12:51
Zitat von alienous:
hm, nur so ne frage, wenn man -5212 in 5212 umwandeln will, wieso multipliziert man dann nich einfach mit x *(-1)

das ganze noch in ne ifabfrage, ob der wert unter 0 ist, und fertig isses doch oder nich?
Ja, viele Wege führen nach Rom, aber nicht alle sind gleich gut oder gleich schnell.
Das IF und besonders die Multiplikation kosten einiges an Performance. Das dürfte auch der Grund sein, warum das ABS() so umgesetzt wird wie oben dargestellt. Das siehr zwar etwas umständlich aus, vermeidet aber die mit einem Vergleich verbundene bedingte Verzweigung.
Gruß, Klaus
Die Titanic wurde von Profis gebaut,
die Arche Noah von einem Amateur.
... Und dieser Beitrag vom Amateurprofi....
  Mit Zitat antworten Zitat
Benutzerbild von 3_of_8
3_of_8

Registriert seit: 22. Mär 2005
Ort: Dingolfing
4.129 Beiträge
 
Turbo Delphi für Win32
 
#9

Re: Rechenaufgabe

  Alt 17. Jul 2006, 12:58
Ich verstehe den Assemblercode nicht so ganz.

Was bedeutet cdq?

Ich hätte jetzt das ganze jetzt (in Delphi) so gemacht:

Delphi-Quellcode:
function abs(value: Integer): Integer;
begin
  if value<0 then result:=(not value)+1 else result:=value;
end;
Manuel Eberl
„The trouble with having an open mind, of course, is that people will insist on coming along and trying to put things in it.“
- Terry Pratchett
  Mit Zitat antworten Zitat
Benutzerbild von gordon freeman
gordon freeman

Registriert seit: 28. Jun 2003
Ort: Gelsenkirchen
337 Beiträge
 
Delphi 2005 Personal
 
#10

Re: Rechenaufgabe

  Alt 17. Jul 2006, 13:10
Zitat von 3_of_8:
Delphi-Quellcode:
function abs(value: Integer): Integer;
begin
  if value<0 do result:=(not value)+1 else result:=value;
end;
Himitsu hatte oben schon eine deutlich bessere Lösung dargestellt.
Allein die Kombination von if und do lässt mir ja schon die Haare zu Berge stehen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 05:11 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