Как использовать цикл для поиска минимального и максимального значений массива в сборке?

Я пытаюсь найти и распечатать минимальное и максимальное значения массива в сборке. Моя основная проблема сейчас заключается в увеличении значения индекса для массива. Я продолжаю получать синтаксические ошибки, когда загружаю свой файл в QTSpim. Я уверен, что есть еще много вопросов, но я доберусь до них позже.

Мой вопрос: почему я не могу увеличить массив до следующего значения? Что такое синтаксическая ошибка?

Вот мой код:

        .data

    array:      .word   5, 7, 12, 3, 4, 9, 6, 11, 2, 10
    array_size: .word   10
    array_min:  .asciiz "\nMin: " 
    array_max:  .asciiz "\nMax: "



    .text
    .globl main

main:   

    la $a1, array       # loading memory address of array

    addi $t0, $zero, 0  # setting index incrementer to 0
    lw $s1, 0($a1)      # setting $s1 to the smallest index of the array
    lw $s2, 0($a1)      # setting $s2 to the smallest index of the array

while:

    beq $t0, 10, exit   # branch to exit if $t0 is 10
    addi $t1, $t1, 4    # too add the next four bytes for the array index

    blt array($t1), $s1, minimum    # branch to minimum if $array[$t1] < $s1 
    blt array($t1), $s2, maximum    # branch to maximum if $array[$t1] < $s2

    minimum:
        lw $s1, array($t1)
        j while
    maximum:
        lw $s2, array($t1)
        j while



    addi $t0, $t0, 1    # increment $t0 by 1

    j while             # jump to the beginning of the while loop

exit:   

    li $v0, 4           # prints the array_min string
    la $a0, array_min
    syscall

    li $v0, 1           # prints the smallest integer
    move $a0, $s1
    syscall

    li $v0, 4           # prints the array_max string
    la $a0, array_max
    syscall

    li $v0, 1           # prints the largest integer
    move $a0, $s2
    syscall


    li $v0, 10          # terminates program
    syscall

Благодарю вас!


person help_me    schedule 24.10.2019    source источник
comment
Какова точная формулировка сообщения об ошибке, которое вы получаете? Включите это в свой вопрос.   -  person Robert Harvey    schedule 24.10.2019
comment
Извините, пишет: spim: (parser) синтаксическая ошибка в строке 26 файла:* blt array($t1, $s1, минимум # перейти к минимуму, если $array[$t1] ‹ $s1   -  person help_me    schedule 24.10.2019
comment
blt не может принимать операнд памяти; это может сделать только загрузка/сохранение. MIPS — это RISC-машина для загрузки/сохранения, а не CISC.   -  person Peter Cordes    schedule 24.10.2019


Ответы (1)


Для чего это стоит, вот рабочий код MIPS, который делает это.

.data

array:      .word   5, 7, 12, 3, 4, 9, 6, 11, 2, 10
array_size: .word   10
array_min:  .asciiz "\nMin: " 
array_max:  .asciiz "\nMax: "

.text

main:   
    la $a0, array
    lw $a1, array_size
    lw $t2, ($a0) # max
    lw $t3, ($a0) # min
    loop_array:
        beq $a1, $zero, print_and_exit
        lw $t0, ($a0)
        bge $t0, $t3, not_min # if (current_element >= current_min) {don't modify min} 
        move $t3, $t0
        not_min:
        ble $t0, $t2, not_max # if (current_element <= current_max) {don't modify max}
        move $t2, $t0
        not_max:
        addi $a1, $a1, -1
        addi $a0, $a0, 4
        j loop_array

    print_and_exit:
    # print maximum
    li $v0, 4
    la $a0, array_max
    syscall

    li $v0, 1
    move $a0, $t2
    syscall 

    # print minimum
    li $v0, 4
    la $a0, array_min
    syscall

    li $v0, 1
    move $a0, $t3
    syscall 

    # exit
    li $v0, 10
    syscall
person Rohit Dwivedula    schedule 26.10.2019