![]() |
Re: Problem mit Binärrechner
Aaalso *g*
Ich hoff, das war verständlich *g* |
Re: Problem mit Binärrechner
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* |
Re: Problem mit Binärrechner
Drei kleine Anmerkungen :wink: :
|
Re: Problem mit Binärrechner
Zitat:
Zu Odd: Das wusste ich, aber das war halt einfach Zusatzinformation ;) Zu shr: Das wollte ich sogar schreiben :oops: Und shl als Gegenteil (also, dass es nachlinks verschiebt) wollte ich auch erwähnen :) Aber jetz is ja alles gesagt ;) |
Re: Problem mit Binärrechner
Sorry wenn ich mich so doof anstelle aber könnt mir einer erklären warum der Code von Marabu funktioniert?
Danke schon mal |
Re: Problem mit Binärrechner
@marabu, das war doch nur spaß -.-°
|
Re: Problem mit Binärrechner
Bitte hört mal langsam aber sicher mit euren Einzeiler-Off-Topic-Posts auf.
Danke. MFG Florian :hi: |
Re: Problem mit Binärrechner
Hi Metatron,
Delphi-Quellcode:
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.
Result := Chr(Ord('0') + Ord(Odd(c))) + Result;
// alternativ: Result := IntToStr(Ord(Odd(c))) + Result; marabu @barf00s: verstehe - willst also nicht helfen... |
Re: Problem mit Binärrechner
danke sehr. so ganz hab ichs zwar noch nich aber ich glaub so halbwegs hab ichs verstanden. ^^
|
Re: Problem mit Binärrechner
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 |
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:26 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz