1.爬楼梯
爬楼梯,他可以每次走1级或者2级,输入楼梯的级数,求不同的走法数
例如:楼梯一共有3级,他可以每次都走一级,或者第一次走一级,第二次走两级
也可以第一次走两级,第二次走一级,一共3种方法。
输入
包含若干行,每行包含一个正整数N,代表楼梯级数,1 <= N <= 30
输出
不同的走法数,每一行输入对应一行输出
提示:隐藏的斐波那契数列
输入输出示例
输入 | 输出 |
---|---|
5 | 8 |
思路:
根据提示可知实际为求斐波那契数列第n项的值f(n),又因为f(5)=8,所以题目为求f(N+1)的值
#include<stdio.h>
long stair(int n)
{
if(n==1 || n==2) //实际上是求斐波那契数列
{
return 1;
}
else
{
return stair(n-1)+stair(n-2);
}
}
int main()
{
int N;
scanf("%d",&N); //&符号不要漏
N++; //数列从第二个开始,所以加一
printf("%d",stair(N));
return 0;
}
2.最大公约数
描述
给定两个正整数,求它们的最大公约数。
输入
输入一行,包含两个正整数(<1,000,000,000)。
输出
输出一个正整数,即这两个正整数的最大公约数。
提示
求最大公约数可以使用辗转相除法:
假设a > b > 0,那么a和b的最大公约数等于b和a%b的最大公约数,然后把b和a%b作为新一轮的输入。
由于这个过程会一直递减,直到a%b等于0的时候,b的值就是所要求的最大公约数。
比如:
9和6的最大公约数等于6和9%6=3的最大公约数。
由于6%3==0,所以最大公约数为3。
输入输出示例
输入 | 输出 |
---|---|
6 |