2D阵列C到MIPS

时间:2019-03-02 20:27:47

标签: c mips

我正在尝试将以下C函数转换为MIPS,但无法弄清楚如何转换其2D数组部分。

    int distance(unsigned arr[15][15],
                          int coord[2], unsigned target) {
      for (int i = 0 ; i < 15 ; ++ i) {
        for (int j = 0 ; j < 15 ; ++ j) {
          if (arr[i][j] == target) {
            return ((i - coord[0]) * (i - coord[0]) +
                    (j - coord[1]) * (j - coord[1]));
       } 
    }

  }
    return -1; 
}

到目前为止,我所拥有的只是MIPS中的double for循环,但是如果有人可以协助我完成if和return语句,那将是很棒的事情。

distance:
    li $t0, 0 # i
    li $t1, 0 # j

    loop_one:
        bge $t0, 15, loop_one_done
        loop_two:
            bge $t1, 15, loop_two_done

            addi $t1, $t1, 1
            j loop_two
        loop_two_done:
            addi $t0, $t0, 1
            j loop_one
    loop_one_done:

    jr  $ra

0 个答案:

没有答案