P1255 数楼梯

P1255 数楼梯

题目描述

楼梯有 NNN 阶,上楼可以一步上一阶,也可以一步上二阶。

编一个程序,计算共有多少种不同的走法。

输入格式

一个数字,楼梯数。

输出格式

输出走的方式总数。

输入输出样例 #1

输入 #1

复制代码
4

输出 #1

复制代码
5

说明/提示

  • 对于 60%60\%60% 的数据,N≤50N \leq 50N≤50;
  • 对于 100%100\%100% 的数据,1≤N≤50001 \le N \leq 50001≤N≤5000。
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

typedef long long ll;	// 严格要求 (将long long 类型取别名为ll)

string dp[10100];

string func(string s1, string s2){
	string s3;
	ll a[10010] = {0};
	reverse(s1.begin(), s1.end());
	reverse(s2.begin(), s2.end());
	
	ll d1 = s1.size(), d2 = s2.size(), d = max(d1, d2);	//d为加一起和的最大下标(注意下标从0开始) 
	for(ll i = d1; i <= d; i++) s1 += '0';
	for(ll i = d2; i <= d; i++) s2 += '0';
	
	ll cnt = 0;
	for(ll i = 0; i <= d; i++){
		ll x1 = s1[i] - '0', x2 = s2[i] - '0', x = x1 + x2 + cnt;
		a[i] = x % 10;
		cnt = x / 10;
	}
	while(a[d] == 0){
		d--;
	}
	for(ll i = d; i >= 0; i--){	
		s3 += char(a[i] + '0');
	}
	return s3;
}

int main(){
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	
	ll n;
	cin >> n;
	dp[1] = "1";
	dp[2] = "2";
	
	for(ll i = 3; i <= n; i++){
		dp[i] = func(dp[i - 1], dp[i - 2]);
//		cout << dp[i] << endl;
	}
	cout << dp[n] << endl;
	return 0;
}
相关推荐
见过夏天4 分钟前
C++ 基础入门完全指南
c++
黄敬峰3 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术4 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六7 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术8 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize9 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营1 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
用户805533698031 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt