Kannst du bitweise multiplizieren?

Kannst du bitweise multiplizieren?
Kannst du bitweise multiplizieren?
Anonim

Eine Zahl kann mitbitweisen Operatoren mit 2 multipliziert werden. Dies geschieht, indem der linke Schiebeoperator verwendet wird und die Bits um 1 nach links verschoben werden. Dies ergibt das Doppelte der vorherigen Zahl. Ein Programm, das die Multiplikation einer Zahl mit 2 unter Verwendung bitweiser Operatoren demonstriert, ist wie folgt angegeben.

Wie multipliziert man mit Bitwise?

Um mit einem beliebigen Wert von 2 hoch N zu multiplizieren (d.h. 2^N) verschiebt die Bits N Mal nach links Um zu dividieren verschiebt die Bits nach rechts. Die Bits sind ganze 1 oder 0 - Sie können also nicht um einen Teil eines Bits verschieben, wenn die Zahl, mit der Sie multiplizieren, keinen ganzen Wert von N faktorisiert, dh

Ist die bitweise Multiplikation schneller?

Bit-Verschiebung ist immer noch schneller, aber für Mul/Div ohne Zweierpotenz ist es wieder langsamer, wenn Sie alle Ihre Verschiebungen machen und die Ergebnisse addieren.

Was ist schnellere Multiplikation oder Division?

Multiplikation ist schneller als Division. An der Universität wurde mir beigebracht, dass die Division das Sechsfache der Multiplikation dauert. Die tatsächlichen Timings sind architekturabhängig, aber im Allgemeinen wird die Multiplikation niemals langsamer oder sogar so langsam sein wie die Division.

Ist Bitshifting schneller als Multiplikation?

Das Verschieben von Bits nach links und rechts ist anscheinend schneller als Multiplikations- und Divisionsoperationen auf den meisten, vielleicht sogar allen CPUs, wenn Sie zufällig eine Potenz von 2 verwenden kann die Klarheit des Codes für einige Leser und einige Algorithmen verringern.

Empfohlen: