Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen der Seite angezeigt.
| Beide Seiten, vorherige Überarbeitung Vorherige Überarbeitung Nächste Überarbeitung | Vorherige Überarbeitung | ||
| ef_informatik:assembler [2024-09-24 10:57] – [4. Vergleiche, Sprünge, Schleifen] sps | ef_informatik:assembler [2024-09-24 14:04] (aktuell) – [6. Funktionen] sps | ||
|---|---|---|---|
| Zeile 286: | Zeile 286: | ||
| <box 100%> | <box 100%> | ||
| - | **Aufgabe 9:** | + | **Aufgabe 9:** Schreibe ein Programm, |
| - | | + | Wenn man dieses Programm z.B. in Python schreibt, implementiert man dazu eine Verzweigung (if-el(se)if). In Assembler wird dies wie eine Schleife (z.B. in letzter Aufgabe) mit Sprüngen |
| - | * zwei Zahlen | + | |
| - | * die grössere | + | <nodisp 1> |
| - | * und ausgibt. | + | ++++Lösung| |
| - | * Wie wird die Verzweigung (if...else...) implementiert? | + | < |
| + | INP R0,2 | ||
| + | INP R1,2 | ||
| + | CMP R0,R1 | ||
| + | BLE LOWER | ||
| + | OUT R0 | ||
| + | BRA DONE | ||
| + | LOWER OUT R1 | ||
| + | DONE HLT | ||
| + | </ | ||
| + | ++++ | ||
| + | </ | ||
| </ | </ | ||
| Zeile 390: | Zeile 401: | ||
| Iterativ: | Iterativ: | ||
| INP R0,2 | INP R0,2 | ||
| - | MOV R1,#1 //Zähler | + | PSH R0 |
| - | MOV R2,#1 //Produkt | + | JMS FCLT |
| + | POP R0 | ||
| + | OUT R0,4 | ||
| + | HLT | ||
| + | FCLT: POP R0 | ||
| + | | ||
| + | MOV R2,#1 //Produkt | ||
| LOOP: MUL R2,R1 | LOOP: MUL R2,R1 | ||
| ADD R1,#1 | ADD R1,#1 | ||
| CMP R1,R0 | CMP R1,R0 | ||
| BLE LOOP | BLE LOOP | ||
| - | | + | |
| - | | + | |