求100-999中的水仙花数,(若三位数abc,abc=a^3+b^3+c^3, 则称abc为水仙花数。如153,1^3+5^3+3^3=1+125+27=153,则153是水仙花数)
#include<stdio.h>
int main()
{
int i;
int a,b,c;
for(i=100;i<1000;i++)
{
a=i/100;
b=(i%100)/10;
c=i%10;
if(i==a*a*a+b*b*b+c*c*c)
printf("%d\n",i);
else
continue;
}
}
以下汇编:
.data
space:.asciiz " "
.text
li $t0,100 #use $t0 as i
li $t1,10
li $t2 100
li $s0,1000
fori:
slt $s1,$t0,$s0
beq $s1,$0,endfori
div $t0,$t2
mflo $t3 #use $t3 as a
mfhi $t4
div $t4,$t1
mflo $t4 #use $t4 as b
div $t0,$t1
mfhi $t5 #use $t5 as c
mult $t3,$t3
mflo $t6
mult $t6,$t3
mflo $t3 #use $t3 as a^3
mult $t4,$t4
mflo $t6
mult $t6,$t4
mflo $t4#use $t3 as a^3
mult $t5,$t5
mflo $t6
mult $t6,$t5
mflo $t5 #use $t3 as a^3
add $t6,$t3,$t4
add $t6,$t6,$t5
beq $t6,$t0,print
addi $t0,$t0,1
j fori
endfori:
j end
print:
move $a0,$t0
li $v0,1
syscall
la $a0,space
li $v0,4
syscall
addi $t0,$t0,1
j fori
end:
li $v0,10
syscall
MIPS 汇编 水仙花数
最新推荐文章于 2022-09-09 10:53:30 发布