0

次の 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
4

1 に答える 1