openjudge 1.5.17 斐波那契数列

OpenJudge - 17:菲波那契数列


解题思路:

1.求斐波那契数列的第k项,那么首先定义两个变量a1和a2,因为后面的一项总是等于前两项的和,并且前两项都为1

2.然后判断一下如果k是小于3的,说明直接可以输出1,因为第一个值和第二个值都是1

3.如果k是大于2的,表示求后面的值,在这里创建一个3-k次的循环,ak=a1+a2,先把前两项的和求出来,然后a1=a2,此时第二项的值赋值给第一项,因为再求下一个数的是,往前移动一个数字

,然后将a2=ak,将两数之和,赋值给a2,此时的a1和a2已经变化了,继续求下一项的值

4.最后输出ak即可


#include<bits/stdc++.h>
using namespace std;
int main()
{
	int k,ak;//定义变量k表示求第k项 
	cin>>k;//输入k的值 

	int a1=1,a2=1;//定义前两项a1和a2均为1 

	if(k==1||k==2)//判断如果k为1或者2的时候 
	cout<<1;//输出1即可 
	else//如果k>2的话,利用循环来求 
	{
		for(int i=3;i<=k;i++)//创建一个3-k的循环 
		{
			ak=a1+a2;//先将前两项求和 
			a1=a2;//然后第二项的值赋值给第一项 
			a2=ak;//他俩的和赋值给第二项 
		}
		cout<<ak;//输出第k项的值 
	}
	return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值