Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | SET R1 1 ; Initialize counter (n) SET R2 1 ; Initialize memory address SET R3 1 ; Initialize value to store (n*n) loop: MUL R3 R1 R1 ; Calculate n*n STORE R3 R2 ; Store n*n at memory address R2 INC R1 ; Increment counter INC R2 ; Increment memory address EQ R1 21 ; Check if we've calculated 20 squares JT end ; If so, jump to end JMP loop ; Otherwise, loop back end: HCF ; Halt and Catch Fire (with pizzazz!) |
I extracted the following code from that output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | SET R1 1 ; Initialize counter (n) SET R2 1 ; Initialize memory address SET R3 1 ; Initialize value to store (n*n) loop: MUL R3 R1 R1 ; Calculate n*n STORE R3 R2 ; Store n*n at memory address R2 INC R1 ; Increment counter INC R2 ; Increment memory address EQ R1 21 ; Check if we've calculated 20 squares JT end ; If so, jump to end JMP loop ; Otherwise, loop back end: HCF ; Halt and Catch Fire (with pizzazz!) |
Resulting in output: False
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | SET R1 1 ; Initialize counter (n) SET R2 1 ; Initialize memory address counter SET R3 1 ; Initialize value to square (n) loop: MUL R4 R1 R1 ; R4 = n * n (calculate square) STORE R4 R2 ; Store the square at memory address R2 INC R1 ; Increment n INC R2 ; Increment memory address counter EQ R1 21 ; Check if n > 20 JT end ; If n > 20, jump to end JMP loop ; Otherwise, loop back end: HCF ; Halt and Catch Fire (with pizzazz!) |
I extracted the following code from that output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | SET R1 1 ; Initialize counter (n) SET R2 1 ; Initialize memory address counter SET R3 1 ; Initialize value to square (n) loop: MUL R4 R1 R1 ; R4 = n * n (calculate square) STORE R4 R2 ; Store the square at memory address R2 INC R1 ; Increment n INC R2 ; Increment memory address counter EQ R1 21 ; Check if n > 20 JT end ; If n > 20, jump to end JMP loop ; Otherwise, loop back end: HCF ; Halt and Catch Fire (with pizzazz!) |
Resulting in output: False
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | SET R1 1 ; Initialize counter (i) SET R2 1 ; Initialize number to square (n) SET R3 0 ; Initialize memory address loop: MUL R4 R2 R2 ; Calculate n*n STORE R4 R3 ; Store n*n at memory address R3 INC R2 ; Increment n INC R3 ; Increment memory address LTE R1 20 ; Check if i <= 20 JT continue ; Jump to continue if true JMP end ; Jump to end if false continue: INC R1 ; Increment i JMP loop ; Jump back to the beginning of the loop end: HCF ; Halt and Catch Fire (with pizzazz!) |
I extracted the following code from that output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | SET R1 1 ; Initialize counter (i) SET R2 1 ; Initialize number to square (n) SET R3 0 ; Initialize memory address loop: MUL R4 R2 R2 ; Calculate n*n STORE R4 R3 ; Store n*n at memory address R3 INC R2 ; Increment n INC R3 ; Increment memory address LTE R1 20 ; Check if i <= 20 JT continue ; Jump to continue if true JMP end ; Jump to end if false continue: INC R1 ; Increment i JMP loop ; Jump back to the beginning of the loop end: HCF ; Halt and Catch Fire (with pizzazz!) |
Resulting in output: True
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | SET R1 1 ; Initialize counter (n) SET R2 1 ; Initialize value (n*n) SET R3 0 ; Initialize memory address loop: STORE R2 R3 ; Store n*n at current memory address INC R1 ; Increment counter n MUL R2 R1 R1 ; Calculate n*n INC R3 ; Increment memory address LT R3 20 ; Check if we've stored 20 squares JT continue ; Jump to continue if less than 20 HCF ; Halt and Catch Fire (with pizzazz!) continue: JMP loop |
I extracted the following code from that output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | SET R1 1 ; Initialize counter (n) SET R2 1 ; Initialize value (n*n) SET R3 0 ; Initialize memory address loop: STORE R2 R3 ; Store n*n at current memory address INC R1 ; Increment counter n MUL R2 R1 R1 ; Calculate n*n INC R3 ; Increment memory address LT R3 20 ; Check if we've stored 20 squares JT continue ; Jump to continue if less than 20 HCF ; Halt and Catch Fire (with pizzazz!) continue: JMP loop |
Resulting in output: True
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
Here is the description of a new assembly language: * 8 registers (R1, R2, R3, R4, R5, R6, R7, R8) that can hold integers. * 1 flag that can hold a boolean value (True or False). * 100 memory addresses (0-99) that can hold integers. * 1 instruction pointer that points to the current instruction being executed. Each instruction is of the form OP ARG1 ARG2 ... where ARGn can be either a register (e.g., R1) or a constant (e.g., 10). Labels are written with a lowercase word followed by colon. The assembly language supports the following instructions: * SET Rx C: Assigns the value C to register Rx. * ADD Rx Ry Rz: Adds the values of Ry and Rz and stores the result in Rx. * (similarly for SUB, MUL, DIV, MOD) * EQ Rx Ry: Sets the flag to True if Rx and Ry are equal, False otherwise. * (similarly for NEQ, LT (Rx < Ry), LTE, GT, GTE) * INC/DEC Rx: Increments/Decrements the value of Rx by one. * JMP L: Jumps to label L unconditionally. * JT/JF (jump if true / jump if false) L: Jumps to label L if the is set or not set. * LOAD Rx M: Loads the value at memory address M into register Rx. * STORE Rx M: Stores the value of register Rx into memory address M. * HCF: Stops the program (with pizzazz) Given this assembly language, write a program that puts the first 20 square (1, 4, 9...) numbers in memory cells 0..19
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | SET R1 1 ; Initialize counter (n) SET R2 1 ; Initialize memory address SET R3 1 ; Initialize value to store (n^2) loop: MUL R3 R1 R1 ; Calculate n*n STORE R3 R2 ; Store n^2 at memory address R2 INC R1 ; Increment counter INC R2 ; Increment memory address LTE R1 20 ; Check if n <= 20 JT loop ; If true, jump to 'loop' HCF ; Halt and Catch Fire (with pizzazz!) |
I extracted the following code from that output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | SET R1 1 ; Initialize counter (n) SET R2 1 ; Initialize memory address SET R3 1 ; Initialize value to store (n^2) loop: MUL R3 R1 R1 ; Calculate n*n STORE R3 R2 ; Store n^2 at memory address R2 INC R1 ; Increment counter INC R2 ; Increment memory address LTE R1 20 ; Check if n <= 20 JT loop ; If true, jump to 'loop' HCF ; Halt and Catch Fire (with pizzazz!) |
Resulting in output: False