AGB  ·  Datenschutz  ·  Impressum  







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

Problem mit Binärrechner

Ein Thema von Metatron220 · begonnen am 19. Jul 2005 · letzter Beitrag vom 21. Jul 2005
Antwort Antwort
Seite 2 von 3     12 3      
Benutzerbild von Ultimator
Ultimator

Registriert seit: 17. Feb 2004
Ort: Coburg
1.860 Beiträge
 
FreePascal / Lazarus
 
#11

Re: Problem mit Binärrechner

  Alt 19. Jul 2005, 19:45
Aaalso *g*
  • Chr Gibt das Zeichen zurück, das den als Parameter angegebenen ASCII-Code hat
  • Ord Macht das Ganze andersrum. Als Parameter wird ein Char erwartet und die Funktion gibt den passenden ASCII-Code zurück.
  • Odd Liefert true zurück, wenn die als Parameter angegebene (ganze) Zahl ungerade ist.
  • shr Verschiebt alle Bits eines Wertes um einen angegebenen Wert

Ich hoff, das war verständlich *g*
Julian J. Pracht
  Mit Zitat antworten Zitat
Metatron220

Registriert seit: 31. Okt 2004
33 Beiträge
 
#12

Re: Problem mit Binärrechner

  Alt 19. Jul 2005, 19:50
Vielen dank für die Erklärungen. Jetzt weiß ich zumindest eins:
nämlich dass ich absolut net weiß wie des mit der umwandlung nach der methode funktioniert. aber trotzdem vielen dank *g*
  Mit Zitat antworten Zitat
Benutzerbild von Khabarakh
Khabarakh

Registriert seit: 18. Aug 2004
Ort: Brackenheim VS08 Pro
2.876 Beiträge
 
#13

Re: Problem mit Binärrechner

  Alt 19. Jul 2005, 19:57
Drei kleine Anmerkungen :
  • Chr Gibt das Zeichen zurück, das den als Parameter angegebenen ASCII-Code hat
  • Ord Macht das Ganze andersrum. Als Parameter wird ein Char erwartet und die Funktion gibt den passenden ASCII-Code zurück. Funktioniert mit allen ordinalen Typen
  • Odd Liefert true zurück, wenn die als Parameter angegebene (ganze) Zahl ungerade ist. Compilermagic, daher schneller als "mod 2" oder "and 1"
  • shr Verschiebt alle Bits eines Wertes um einen angegebenen Wert nach rechts
Oder einfach:
Sebastian
Moderator in der EE
  Mit Zitat antworten Zitat
Benutzerbild von Ultimator
Ultimator

Registriert seit: 17. Feb 2004
Ort: Coburg
1.860 Beiträge
 
FreePascal / Lazarus
 
#14

Re: Problem mit Binärrechner

  Alt 19. Jul 2005, 20:06
Zitat von Khabarakh:
Drei kleine Anmerkungen :
  • Chr Gibt das Zeichen zurück, das den als Parameter angegebenen ASCII-Code hat
  • Ord Macht das Ganze andersrum. Als Parameter wird ein Char erwartet und die Funktion gibt den passenden ASCII-Code zurück. Funktioniert mit allen ordinalen Typen
  • Odd Liefert true zurück, wenn die als Parameter angegebene (ganze) Zahl ungerade ist. Compilermagic, daher schneller als "mod 2" oder "and 1"
  • shr Verschiebt alle Bits eines Wertes um einen angegebenen Wert nach rechts
Oder einfach:
OK, zu Ord: Das wusst ich gar nicht Habs nur in Verbindung mit Chars gebraucht
Zu Odd: Das wusste ich, aber das war halt einfach Zusatzinformation
Zu shr: Das wollte ich sogar schreiben Und shl als Gegenteil (also, dass es nachlinks verschiebt) wollte ich auch erwähnen

Aber jetz is ja alles gesagt
Julian J. Pracht
  Mit Zitat antworten Zitat
Metatron220

Registriert seit: 31. Okt 2004
33 Beiträge
 
#15

Re: Problem mit Binärrechner

  Alt 20. Jul 2005, 16:05
Sorry wenn ich mich so doof anstelle aber könnt mir einer erklären warum der Code von Marabu funktioniert?
Danke schon mal
  Mit Zitat antworten Zitat
barf00s
(Gast)

n/a Beiträge
 
#16

Re: Problem mit Binärrechner

  Alt 20. Jul 2005, 16:23
@marabu, das war doch nur spaß -.-°
  Mit Zitat antworten Zitat
Benutzerbild von flomei
flomei

Registriert seit: 17. Jan 2003
Ort: Schieder-Schwalenberg
2.094 Beiträge
 
Delphi 2005 Personal
 
#17

Re: Problem mit Binärrechner

  Alt 20. Jul 2005, 16:29
Bitte hört mal langsam aber sicher mit euren Einzeiler-Off-Topic-Posts auf.
Danke.

MFG Florian
Florian Meier
... ist raus.
Vielen Dank für die Zeit mit euch!
http://www.flomei.de -- http://www.md5hash.de
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#18

Re: Problem mit Binärrechner

  Alt 20. Jul 2005, 16:52
Hi Metatron,

Delphi-Quellcode:
Result := Chr(Ord('0') + Ord(Odd(c))) + Result;
// alternativ: Result := IntToStr(Ord(Odd(c))) + Result;
Odd(c) ist true für ungerade c, die ganze Zeile ist Zeichen-Arithmetik. Wenn es auf ein paar-zig CPU-Zyklen nicht ankommt, dann kannst du auch IntToStr() verwenden. In der Schleife wird immer nur das least significant bit (bit 0) betrachtet und anschließend durch bitweises Schieben eliminiert.

marabu

@barf00s: verstehe - willst also nicht helfen...
  Mit Zitat antworten Zitat
Metatron220

Registriert seit: 31. Okt 2004
33 Beiträge
 
#19

Re: Problem mit Binärrechner

  Alt 20. Jul 2005, 17:27
danke sehr. so ganz hab ichs zwar noch nich aber ich glaub so halbwegs hab ichs verstanden. ^^
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#20

Re: Problem mit Binärrechner

  Alt 20. Jul 2005, 17:52
Nochmal - anderer Ansatz:

Denke dir eine Zahl -- 5 ist gut. Die 5 als Dualzahl sieht etwa so aus: 101
In der Schleife nehme ich das rechte bit und wandle es in das Zeichen '1' um (ASCII-Code 49), baue das Zeichen in einen String so ein, dass es an der dem bit entsprechenden Stelle steht, danach schubse ich alle bits um eine Stelle nach rechts, wobei die 1 von eben in ein Wurmloch fällt.
Das geht solange, bis keine bits mit dem Wert 1 mehr vorkommen.

Jetzt klarer?

marabu
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 3     12 3      


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 16:10 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