【MIPS汇编简单算法实例 Lab10】斐波那契数列 【详细】

【MIPS汇编简单算法实例 Lab10】斐波那契数列

实验二 斐波那契数列

一、概述

1.定义:

斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……在数学上,斐波那契数列以如下被以递推的方法定义:F(0)=0,F(1)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 2,n ∈ N*)

2.递推公式

斐波那契数列:

在这里插入图片描述

如果设an为该数列的第n项
那么这句话可以写成如下形式:

在这里插入图片描述

二、MIPS汇编实现斐波那契数列

【输入】 整数n,斐波那契数列的第n项
【输出】斐波那契数列的第n项的值

1.Data域变量声名

在这里插入图片描述

Prompt .asciiz:“please input a value:” 提示用户输入斐波那契数列的某项
result .asciiz:”result is :” 提示输出内容

2.寄存器功能分配

在这里插入图片描述

$t0 存用户输入的第n项的 n值
$t1 初始值0(斐波那契数列第一项),用于记录 f[n-2]
$t2 初始值1(斐波那契数列第二项),用于记录 f[n-1]
$t3 当前所在项的索引
$t4 (斐波那契数列当前项),用于记录 f[n]

3.源代码

初始化部分
在这里插入图片描述

核心算法(迭代实现)

在这里插入图片描述

4.运行测试

【输入】1
【输出】

在这里插入图片描述

【输入】3
【输出】
在这里插入图片描述

【输入】19
【输出】
在这里插入图片描述

【输入】7
【输出】
在这里插入图片描述

经验证,本程序设计成功完成了预期设计目标。

源码:

.data
	prompt:.asciiz "please input a value:"
	result:.asciiz "result:"
.text
main:
	li $v0,4
	la $a0,prompt
	syscall
	li $v0,5
	syscall
	move $t0,$v0
	beq $t0,1,input_1
	beq $t0,2,input_2
	
	li $t1,0
	li $t2,1
	li $t4,1
	li $t3,4 #2+2
loop:
	bgt $t3,$t0,out
	move $t1,$t2
	move $t2,$t4
	add $t4,$t1,$t2
	
	addi $t3,$t3,1
	b loop
input_1:
	li $t4,0
	b out
input_2:
	li $t4,1
	b out
out:
	li $v0,4
	la $a0,result
	syscall
	li $v0,1
	move $a0,$t4
	syscall
	
	li $v0,10
	syscall

	

在这里插入图片描述

  • 8
    点赞
  • 93
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值