洛谷题单P1255 数楼梯

洛谷题单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];
	}
}码片
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值