MIPS сортировка и массив - PullRequest
1 голос
/ 12 ноября 2010

У меня проблема с домашним заданием.Я предполагаю написать программу, которая делает следующее:

  1. Сортировка букв в предложении в последовательность сортировки ASCII (т.е. в алфавитном порядке).Выведите результаты и общее количество символов в предложении.
  2. Затем распечатайте список количества раз, которое каждая буква встречалась в предложении.
  3. Наконец, выведите общее количестворазличных символов в предложении.

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

        .data
length: .word   0
buffer: .space 255
prompt1:.asciiz  "Type in a sentence: "

after:  .asciiz  "\nString  after: "


    .text


# Start of code section

main:
      li       $v0, 4         # Prompt user for a text string
      la       $a0, prompt1      # address of string to print
      syscall
      li       $v0, 8         # Read in text string
      la       $a0, buffer
      li       $a1, 255
      syscall

      la       $t0, buffer    #  Read character from text string
      lw       $t1, length
      addu     $t0, $t0, $t1

# Call on QuickSort

        la      $a0, buffer       # Constant pointer to string

        add     $a1, $a0, 0      # Pointer to left end

        add     $a2, $a0, 25     # Pointer to right end

        jal     QS               # The one call from main

# Print out results

        la      $a0, after

        li      $v0, 4

        syscall

        la      $a0, buffer

        syscall

# End main

        li      $v0, 10

        syscall


QS:     sub     $sp, $sp, 16     # \
        sw      $a1, 0($sp)      #  \

        sw      $a2, 4($sp)      #   > Save registers

        sw      $t2, 8($sp)      #  /  

        sw      $ra, 12($sp)     # / and return address

        bge     $a1, $a2, QSret  # Nothing to sort   

        sub     $t3, $a1, $a0     # index i

        sub     $t4, $a2, $a0     # index j

        add     $t0, $t3, $t4     # t0 = i+j choose middle

        sra     $t0, $t0, 1       # t0 = (i+j) div 2

        add     $t0, $t0, $a0     # t0 -> A[(i+j) div 2]

        lb      $t5, 0($t0)       # t5 = pivot value 

        lb      $t6, 0($a1)       # t6 = A[i] = left element

        sb      $t5, 0($a1)       # Swap them so pivot

        sb      $t6, 0($t0)       # is first element
# 

        move    $t1, $a1         # Initdially i -> first (pivot) item a1

        add     $t2, $a2, 1      # Initially j -> just past last item a2

        lb      $t0, 0($a1)      # Pivot value in t0 (in $t5)

# 
loop:
# 

i_loop: add     $t1, $t1, 1      # i=i+1;

        lb      $t5, 0($t1)      # t5 = A[i]

        bgt     $t0, $t5, i_loop # until pivot <= A[i]

j_loop: sub     $t2, $t2, 1      # j=j-1;

        lb      $t6, 0($t2)      # t6 = A[j]

        blt     $t0, $t6, j_loop # until pivot >= A[j]
#

        bge     $t1, $t2, test   # if i<j swap
#

        sb      $t6, 0($t1)      # A[i] and

        sb      $t5, 0($t2)      # A[j]
#

test:   blt     $t1, $t2, loop   # until i >= j
#

        lb      $t5, 0($a1)      # swap a[a1] = pivot

        lb      $t6, 0($t2)      # and a[j]

        sb      $t5, 0($t2)      # now a[j] is

        sb      $t6, 0($a1)      # in its final position

# Done with partition

        lw      $a1, 0($sp)

        sub     $a2, $t2, 1

        jal     QS               # Recursive call on left

        add     $a1, $t2, 1

        lw      $a2, 4($sp)

        jal     QS               # Recursive call on right
#

QSret:  lw      $ra, 12($sp)     # \Replace return address

        lw      $t2, 8($sp)      #  \

        lw      $a2, 4($sp)      #   > and registers

        lw      $a1, 0($sp)      #  /
        add     $sp, $sp, 16     # /

        jr      $ra

1 Ответ

1 голос
/ 13 ноября 2010
buffer: .space 255

Это заполняет buffer нулями.

li       $v0, 8         # Read in text string
la       $a0, buffer
li       $a1, 255
syscall

Я не знаю, какую среду вы используете, но обычно это работает так же, как fgets() в C, так что если вывведите hello, ваш буфер будет выглядеть как:

+-----+-----+-----+-----+-----+-----+-----+-----+   more    +-----+
| 'h' | 'e' | 'l' | 'l' | 'o' |'\n' |  0  |  0  |..zeroes...|  0  |
+-----+-----+-----+-----+-----+-----+-----+-----+           +-----+

Код, который после этого, кажется, не делает ничего полезного:

la       $t0, buffer    #  Read character from text string
lw       $t1, length
addu     $t0, $t0, $t1

, но length никогдазаписано и $t0 больше не используется (пока не будет перезаписано внутри QS).

Вызов QS передает фиксированное значение в $a2 (25 - почему?).Предполагая, что подпрограмма QS на самом деле работает так, как объявлено: если ваша исходная строка короткая, некоторые из нулевых байтов в буфере будут включены в сортируемый диапазон и, таким образом, окажутся в начале буфера -отсортированный диапазон будет выглядеть примерно так:

+-----+   more    +-----+-----+-----+-----+-----+-----+-----+-----+
|  0  |..zeroes...|  0  |  0  |'\n' | 'e' | 'h' | 'l' | 'l' | 'o' |
+-----+           +-----+-----+-----+-----+-----+-----+-----+-----+

, т. е. если сортируемый диапазон содержит нулевые байты, первый байт результата будет равен нулю, и поэтому вы напечатаете пустую строку.

Часть 2: если у вас есть правильно отсортированная строка, это должно быть просто, так как все вхождения каждого символа смежны.Просто пройдите вдоль строки и подумайте, является ли каждый символ тем же, что и предыдущий, или другим.

Часть 3: просто нужен дополнительный счетчик при выполнении работы для части 2.

...