洛谷题单P1255 数楼梯
思路:因为官方给出的数据为:对于60% 的数据,N≤50;
对于100%* 的数据,1≤N≤5000。所以单纯使用递归会栈溢出
并且还会数据溢出。所以我们要使用递推的方法。
可以使用字符串或数组来解题
以下采用数组解答
#include<iostream>
using namespace std;
#include<bits/stdc++.h>
int len;
void def(int i,vector<vector<int>>&dp){
for(int j=1;j<=len;j++)
{
dp[i][j]=dp[i-1][j]+dp[i-2][j];//前两个楼梯数相加之和
}
for(int j=1;j<=len;j++)//相加完后,判断第i行的每位数是否小于10,大于则进位
{
if(dp[i][j]>=10)//处理数字的进位
{
dp[i][j+1]+=dp[i][j]/10;
dp[i][j]=dp[i][j]%10;
if(dp[i][len+1]>0)//最后一位大于0,长度加一
{
len++;
}
}
}
}
int main()
{ len=1;//一开始数字长度为1
int N;
cin>>N;//楼梯数
vector<vector<int>>dp(5010,vector<int>(5010));//用数组来存储巨大的数字;一个二维数组下标上存储一个数字//每行存储一个楼梯的总走发
//i=10时就代表 楼梯10的行走方案总数
dp[1][1]=1;dp[2][1]=2;初始化楼梯1和楼梯2的行走方案总数
for(int i=3;i<=N;i++)//遍历每个楼梯
{
def(i,dp);
}
for(int j=len;j>=1;j--)//倒序输出数组
{
cout<<dp[N][j];
}
}码片