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 (1011.0000)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:

(1011.0000)2 = 0⋅1 + 0⋅2 + 0⋅4 + 0⋅8 + 1⋅16 + 1⋅32 + 0⋅64 + 1⋅128= 176

Somit ergibt sich die Dezimaldarstellung von (1011.0000)2 = 176

Binär aus Dezimal

Beispiel:

Gib die Zahl 91 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 91 als Summe von 2er-Potenzen (siehe rechts) zu schreiben:

91 = 64 + 27
= 64 + 16 + 11
= 64 + 16 + 8 + 3
= 64 + 16 + 8 + 2 + 1

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

Somit ergibt sich die Binärdarstellung von 91 = (101.1011)2

Binäres Addieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

              (1.0010.0010)2
              +  (110.1000)2

Lösung einblenden

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

              (1.0010.0010)2
              +  (110.1000)2
                 11      
              (1 1000 1010)2

Binäres Subtrahieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

               ( 0111.1001)2
             - ( 0000.1111)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 (0000.1111)2
zu (1111.0000)2

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

               ( 1111.0000)2
             + ( 0000.0001)2
                         
               ( 1111 0001)2

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

               ( 0111.1001)2
             + ( 1111.0001)2
               1 111    1
              (1 0110 1010)2

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

(0110.1010)2

Binäres Multiplizieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

(101.1001)2 ⋅ (1010.0100)2 =

Lösung einblenden

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

                      (100)2
                  (10.0000)2
             + ( 1000.0000)2
               ( 1010 0100)2

somit gilt:

(101.1001)2 ⋅ (1010.0100)2 = 101.1001 ⋅ (1000.0000 + 10.0000 + 100)

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

(101.1001)2 ⋅ (1010.0100)2 = (10.1100.1000.0000)2 + (1011.0010.0000)2 + (1.0110.0100)2

Diese 3 Summanden können wir nun schrittweise addieren:

              (1.0110.0100)2
        + ( 1011.0010.0000)2
             11  11      
          ( 1100 1000 0100)2

Zu diesem Ergebnis dann die nächste Zahl dazu:

          ( 1100.1000.0100)2
     +  (10.1100.1000.0000)2
          1 1  1         
        (11 1001 0000 0100)2

Das Ergebnis ist somit: (11.1001.0000.0100)2

(Zum Vergleich in Dezimalzahlen: 89 ⋅ 164 = 14596)

Binäres Dividieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

(1.0100.0100)2 : (1100)2 =

Lösung einblenden
101000100 : 1100 = 11011    
- 1100                       
10000                      
- 1100                      
01001                     
- 0000                     
10010                    
- 1100                    
01100                   
- 1100                   
0000                   
  • Die obige Differenz (10100)2 - (1100)2 = (1000)2 kann man entweder mit binärer Subtraktion berechnen oder - oft schneller - durch Umrechnen in Dezimalzahlen: 20 - 12 = 8
  • Die obige Differenz (10000)2 - (1100)2 = (100)2 kann man entweder mit binärer Subtraktion berechnen oder - oft schneller - durch Umrechnen in Dezimalzahlen: 16 - 12 = 4
  • Die obige Differenz (10010)2 - (1100)2 = (110)2 kann man entweder mit binärer Subtraktion berechnen oder - oft schneller - durch Umrechnen in Dezimalzahlen: 18 - 12 = 6
  • Die obige Differenz (01100)2 - (1100)2 = (0)2 kann man entweder mit binärer Subtraktion berechnen oder - oft schneller - durch Umrechnen in Dezimalzahlen: 12 - 12 = 0

(Zum Vergleich in Dezimalzahlen: 324 : 12 = 27)

Binäres Subtrahieren

Beispiel:

Berechne ohne die Binärzahlen in Dezimalzahlen umzuwandeln:

               ( 0111.1100)2
             - ( 0110.0010)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 (0110.0010)2
zu (1001.1101)2

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

               ( 1001.1101)2
             + ( 0000.0001)2
                        1
               ( 1001 1110)2

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

               ( 0111.1100)2
             + ( 1001.1110)2
               1 1111 1  
              (1 0001 1010)2

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

(0001.1010)2