次の c または Java ライクなコードを考えてみましょう:
int i = 0; int x = 5; int A[10];
10 個の要素を持つ整数の配列を宣言しますwhile (i < 10) { A[i] = i+x; i++; }
プログラムを実装する MIPS プログラムを作成します。できるだけ少ない命令を使用します。
私はこれを理解できないようです。これが私がやったことです。
# i=0, x=5. Array is 10 elements. (While i<10, A[i]=i+x, i++.)
# Array should be [5,6,7,8,9,10,11,12,13,14]
.data
intgrs: .word 0:10 # array of 10 elements to contain integers
size: .word 10 #size of array
.text
.globl main
main:
la $t0, intgrs # load address or array
la $t5, size # load address of size variable
lw $t5, 0($t5) #load array size
li $t2, 0 # i=0
li $t6, 5 # x=5
loop:
add $t4, $t2, $t6 # i+x
sw $t4, 0($t0) # A[0] = 0+5 = 5
add $t2, $t2, 1 # i++
beq $t2, $t5, loop
exit: li $v0, 10 # exit system call
syscall