Ir ao conteúdo
  • Cadastre-se

Nunes_grf

Membro Júnior
  • Posts

    1
  • Cadastrado em

  • Última visita

Reputação

0
  1. Olá, comecei a escrever em Assembly MIPS (Simulador MARS) faz algumas poucas semanas para um projeto da faculdade; Um dos exercícios que eu preciso fazer é escrever um algoritmo que inverta uma string, o que tem sido um pesadelo, ainda não trabalhamos com dispositivos de entrada e de saída, então os valores de entrada e de saída tem que ser gravados na memoria e não mostrados na tela; Gostaria da ajuda de vocês pra consertar o meu código, tenho pouquíssima experiência com a linguagem portanto não estou conseguindo, segue o código abaixo: .data ENTRADA: .asciiz "casa" .text main: la $a0, ENTRADA jal strlen j reversa strlen: addi $t0, $zero, 0 #zerando o contador, $t0 guarda o tamanho da string; loop: lb $t1, 0($a0) # carrega o proximo byte dentro de t2; beqz $t1, fimloop # se $t2 for 0 (fim da string) pula pra saida; addi $a0, $a0, 1 # incrementa o pointeiro da string; addi $t0, $t0, 1 # incrementa o contador; j loop fimloop: add $a1, $t0, $zero #transfere para $a1 o tamanho da string ($t0) jr $ra reversa: add $t0,$a0,$zero #endereço de inicio add $t1,$zero,$zero #inicializa $t1 como contador: i = 0 addi $t2,$a1,-1 #inicia $t1 como contador: j = tamanho - 1 loop2: #do { } while; #carregando byte em $t4 para o indice i add $t3, $t0, $t1 lb $t4, 0($t3) #carregando byte em $t6 para o indice j add $t5, $t0, $t2 lb $t6, 0($t5) #revertendo os caracteres sb $t4,0($t5) #String[j]=String sb $t6,0($t3) #String=String[j] #incrementando i e j addi $t1,$t1,1 #i++ addi $t2,$t2,-1 #j-- #teste para repetir o loop slt $t6,$t2,$t1 beqz $t6,loop2 #testa se j >= i, caso seja, o loop se reinicia FIM:

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...