码迷,mamicode.com
首页 > 其他好文 > 详细

九度OJ 1205 N阶楼梯上楼问题 (DP)

时间:2014-12-23 12:21:35      阅读:114      评论:0      收藏:0      [点我收藏+]

标签:九度oj   1205   

题目1205:N阶楼梯上楼问题

时间限制:1 秒

内存限制:128 兆

特殊判题:

提交:2817

解决:1073

题目描述:

N阶楼梯上楼问题:一次可以走两阶或一阶,问有多少种上楼方式。(要求采用非递归)

输入:

输入包括一个整数N,(1<=N<90)。

输出:

可能有多组测试数据,对于每组数据,
输出当楼梯阶数是N时的上楼方式个数。

样例输入:
4
样例输出:
5

基本思路:
走到第n阶时可能是从第n-1阶走一步到的,也可能是从n-2阶走两阶到的,
设F(n)为走到n阶的走法数量,则状态转移方程为
F(n)=F(n-1)+F(n-2).

#include<stdio.h>
#include<string.h>
long long f[100];
int main(int argc, char *argv[])
{
    int n;
    while(~scanf("%d",&n))
    {
        memset(f,0,sizeof(f));
        f[0]=f[1]=1;
        for(int i=2;i<=n;++i)
            f[i]=f[i-1]+f[i-2];
        printf("%lld\n",f[n]);
    }
    return 0;
}



九度OJ 1205 N阶楼梯上楼问题 (DP)

标签:九度oj   1205   

原文地址:http://blog.csdn.net/wdkirchhoff/article/details/42100975

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!