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;
}
相关推荐
叶~小兮7 分钟前
K8S进阶核心综合学习笔记(持久化存储+特殊容器+调度管理)
笔记·学习·kubernetes
香蕉鼠片11 分钟前
算法过程中不会的
开发语言·c++
阿旭超级学得完19 分钟前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
輕華19 分钟前
uv工具详解——Python包与项目管理器完全指南
开发语言·python·uv
li星野20 分钟前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法
jerryinwuhan24 分钟前
hello算法,简单讲(1)
算法·排序算法
y = xⁿ27 分钟前
20天速通LeetCodeday15:BFS广度优先搜索
算法·宽度优先
400分30 分钟前
吃透RAG核心-----语义检索与关键字检索底层原理
算法·架构
目黑live +wacyltd38 分钟前
算法备案:常见驳回原因与应对策略
人工智能·算法