我正在尝试将以下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