Я не хочу отдавать его, поэтому я приведу некоторые рекомендации.
Вы должны прочитать Ассемблеры, компоновщики и симулятор Spim . Это большая помощь.
Итак, вот и все.
Создайте два массива из 15 слов.
.data
fail_vector: .word -1,-1,-1 ... #15 invalid words
passed_vector: .word -1,-1,-1 ... #15 invalid words
Загрузить в какой-либо регистр переменную управления циклом.
li $t1,15
beq $t1,$zero,END
addiu $t1,$t1,-1
Теперь внутри этого цикла читаем значения
syscall... #SYS_READ
Затем прочитайте это значение (предположим, оно есть в регистре t4) и решите, сохранять ли его в векторе ошибок или передать вектор.
addiu t4,t4,-50 #subtract 50 from input value.
blez t4,FAILED #If its lower than 0, then read value is lower than 50 ->FAIL
PASSED:
#STORE VALUE INTO passed_vector
FAILED:
#STORE VALUE INTO failed_vector
Когда вы закончите со всеми 15 значениями, распечатайте векторы. Это довольно сложно.
Перед использованием вашей программы вы должны заполнить оба вектора некоторым недопустимым значением, например -1.
Поэтому, когда вы печатаете вектор на экране, вы должны остановиться, когда найдете одно из этих недопустимых значений. И пока вы на нем, держите счетчик, чтобы показать, сколько прошло / не прошло.
в псевдокоде
for both arrays
for (i in (0,15) and array[i] not -1)
print array[i]
add 1 to scores count //to count passed - failed test scores.
сборка (заполните пробелы)
END:
li $t4,15
li $t1,0
beq $t1,$t4,EXIT #condition. While ( i < 15) kind of thing.
addiu $t1,$t1,-1
#print out vectors and keep count on other registers
#then print them out.
syscall... #SYS_WRITE
EXIT: #exit syscall here.
Еще одна сложная проблема - индексация этих векторов. Поскольку они являются массивами слов, вам нужно умножить на 4 (при условии 32-битных слов) переменную управления цикла (классическая переменная i в C), чтобы индексировать вектор. Если бы они были байтовыми массивами, то не было бы необходимости в умножении. И если бы они были короткими массивами ... (ну, вы поняли мою точку зрения)
Например:
passed_vector[i] #(C style sintax)
и пусть переменная i будет храниться в регистре $ t1
получится как:
sll $t2,$t1,2 #i * sizeof(word)
la $a0,passed_vector #$a0 points to passed_vector
add $a0,$a0,$t2 #$a0 now points to passed_vector + i
Так что теперь вы можете загружать / сохранять в sent_vector [i]
sw $t3,0($a0) #0($a0) is passed_vector[0]
lw $t3,0($a0)
Один из способов решения подобных проблем (то есть написание на ассемблере) - это написать программу на C (или на другом языке, который вы знаете), а затем перевести ее на ассемблер, инструкцию на инструкцию.