MIPS-在数组中找不到最小值时遇到麻烦

时间:2018-10-15 04:51:42

标签: arrays assembly mips mips32

所以给了我一个作业,我应该在该作业中以MIPS汇编语言在用户创建的10位数组中查找最大值和最小值的索引。我已经能够找到最大值,但是找不到最小值。我认为一旦找到最大值,这应该是一个简单的解决方案,但是我错了。

这就是我要找到的最大值:

deleteMax:
# $s7 is the register where the address of the array is stored
# $s0 is the register where the array size is stored

# Clear out unimportant registers
addi $s1, $zero, 0
addi $t0, $zero, 0
addi $s3, $zero, 0
addi $s4, $zero, 0
addi $t6, $zero, 0
addi $t7, $zero, 0

addi $t0, $zero, 0               # Address of first element in bytes
li $t3, -1                       # Max index
li $s2, 0                        # Max value
li $t1, 0                        # Counter


loop:
sll $s1, $t1, 2
add $s1, $s1, $s7
lw $s3, 0($s1)                   # Load the first element into $s3
li $v0, 1
move $a0, $s3
syscall


slt $t2, $s3, $s2      # If $s3 < $s2, $t2 = 1, if $s3 >= $s2, $t2 = 0
bne $t2, $zero, find_max
ori $s2, $s3, 0            # Updates the maximum value
ori $t3, $t1, 0            # Updates the maximum value index

find_max:
addi $t1, $t1,1           # Increase the counter
bne $t1, $s0, loop        # if the counter hasn't reached the end, go 
                          back to the loop
j print_max

这就是我想要的:查找最大值及其索引。但是,当我尝试切换这两行代码时:

slt $t2, $s3, $s2      # If $s3 < $s2, $t2 = 1, if $s3 >= $s2, $t2 = 0
bne $t2, $zero, find_max

可以说:

slt $t2, $s3, $s2      # If $s3 < $s2, $t2 = 1, if $s3 >= $s2, $t2 = 0
bne $t2, 1, find_max

最小值变为0?

我不确定为什么会发生这种情况,也不确定如何在当前情况下找到最小值。

我希望我已经解释了我自己,我的代码和注释已经足够说明了这种情况。我很乐意回答你们可能遇到的更多困惑。

0 个答案:

没有答案