nach Aufgabentypen suchen

Aufgabentypen anhand von Beispielen durchstöbern

Browserfenster aktualisieren (F5), um neue Beispiele bei den Aufgabentypen zu sehen

Dezimal aus Binär

Beispiel:

Gib die Zahl (110)2 im Dezimalsystem an.

Lösung einblenden

Als Dezimalzahl

20 = 1
21 = 2
22 = 4
23 = 8
24 = 16
25 = 32
26 = 64
27 = 128
28 = 256
29 = 512
...

Um die (für uns normale) Dezimalzahl zu berechnen, müssen wir einfach jede Ziffer mit der zugehörigen 2er-Potenz ihrer Stelle (siehe rechts) multiplizieren. Am besten tun wir das von rechts nach links:

(110)2 = 0⋅1 + 1⋅2 + 1⋅4= 6

Somit ergibt sich die Dezimaldarstellung von (110)2 = 6

Binär aus Dezimal

Beispiel:

Gib die Zahl 167 im Binärsystem an.

Lösung einblenden
20 = 1
21 = 2
22 = 4
23 = 8
24 = 16
25 = 32
26 = 64
27 = 128
28 = 256
29 = 512
...

Zuerst versuchen wir Schritt für Schritt die Zahl 167 als Summe von 2er-Potenzen (siehe rechts) zu schreiben:

167 = 128 + 39
= 128 + 32 + 7
= 128 + 32 + 4 + 3
= 128 + 32 + 4 + 2 + 1

= 1⋅128 + 0⋅64 + 1⋅32 + 0⋅16 + 0⋅8 + 1⋅4 + 1⋅2 + 1⋅1

Somit ergibt sich die Binärdarstellung von 167 = (1010.0111)2

Binäres Addieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

              (1.0001.1110)2
             + ( 1000.0101)2

Lösung einblenden

Wir schreiben die beiden Binärzahlen untereinander und gehen wie beim schriftlichen Addieren von Dezimalzahlen vor:

              (1.0001.1110)2
             + ( 1000.0101)2
                   11 1  
              (1 1010 0011)2

Binäres Subtrahieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

               ( 0110.0101)2
             - ( 0101.0001)2

Lösung einblenden

Wir wandeln erst den Subtrahend b, also die untere Zahl, die angezogen wird, in ihre negative Zahl um, so dass wir dann einfach die beiden Zahlen addieren können (a-b = a+(-b).

Wir invertieren im ersten Schritt unsere Binärzahl (d.h. aus jeder 0 wird eine 1 und aus jeder 1 wird eine 0).

so wird (0101.0001)2
zu (1010.1110)2

Jetzt müssen wir nur noch die binäre 1 auf diese invertierte Zahl draufaddieren:

               ( 1010.1110)2
             + ( 0000.0001)2
                         
               ( 1010 1111)2

Jetzt können wir einfach a=(0110.0101)2 und -b = (1010.1111)2 addieren:

               ( 0110.0101)2
             + ( 1010.1111)2
               1 11 1 111
              (1 0001 0100)2

Da wir ja aber nur 8-Bit Speicherplatz haben "verpufft der Overflow" und als Ergebnis stehen nur die 8 rechten Bit:

(0001.0100)2

Binäres Multiplizieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

(111.0111)2 ⋅ (100.0010)2 =

Lösung einblenden

Der zweite Faktor (100.0010)2 lässt sich als Summe von reinen 2-er-Potenzen schreiben:

                       (10)2
              +  (100.0000)2
                 (100 0010)2

somit gilt:

(111.0111)2 ⋅ (100.0010)2 = 111.0111 ⋅ (100.0000 + 10)

Das Multiplizieren mit einer 2-er-Potenz bedeutet aber ja, dass man einfach die entsprechende Anzahl an Nullen hintenanhängt, somit gilt:

(111.0111)2 ⋅ (100.0010)2 = (1.1101.1100.0000)2 + (1110.1110)2

Diese 2 Summanden können wir nun schrittweise addieren:

               ( 1110.1110)2
       + (1.1101.1100.0000)2
              11 1       
         (1 1110 1010 1110)2

Das Ergebnis ist somit: (1.1110.1010.1110)2

(Zum Vergleich in Dezimalzahlen: 119 ⋅ 66 = 7854)

Binäres Dividieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

(111.1110)2 : (1001)2 =

Lösung einblenden
1111110 : 1001 = 1110       
- 1001                        
01101                       
- 1001                       
01001                      
- 1001                      
00000                     
- 0000                     
0000                     
  • Die obige Differenz (1111)2 - (1001)2 = (110)2 kann man entweder mit binärer Subtraktion berechnen oder - oft schneller - durch Umrechnen in Dezimalzahlen: 15 - 9 = 6
  • Die obige Differenz (01101)2 - (1001)2 = (100)2 kann man entweder mit binärer Subtraktion berechnen oder - oft schneller - durch Umrechnen in Dezimalzahlen: 13 - 9 = 4
  • Die obige Differenz (01001)2 - (1001)2 = (0)2 kann man entweder mit binärer Subtraktion berechnen oder - oft schneller - durch Umrechnen in Dezimalzahlen: 9 - 9 = 0

(Zum Vergleich in Dezimalzahlen: 126 : 9 = 14)

Binäres Subtrahieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

               ( 0110.0011)2
             - ( 0100.0100)2

Lösung einblenden

Wir wandeln erst den Subtrahend b, also die untere Zahl, die angezogen wird, in ihre negative Zahl um, so dass wir dann einfach die beiden Zahlen addieren können (a-b = a+(-b).

Wir invertieren im ersten Schritt unsere Binärzahl (d.h. aus jeder 0 wird eine 1 und aus jeder 1 wird eine 0).

so wird (0100.0100)2
zu (1011.1011)2

Jetzt müssen wir nur noch die binäre 1 auf diese invertierte Zahl draufaddieren:

               ( 1011.1011)2
             + ( 0000.0001)2
                       11
               ( 1011 1100)2

Jetzt können wir einfach a=(0110.0011)2 und -b = (1011.1100)2 addieren:

               ( 0110.0011)2
             + ( 1011.1100)2
               1 11      
              (1 0001 1111)2

Da wir ja aber nur 8-Bit Speicherplatz haben "verpufft der Overflow" und als Ergebnis stehen nur die 8 rechten Bit:

(0001.1111)2