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;
}
相关推荐
A.A呐2 小时前
【C++第二十一章】set与map封装
开发语言·c++
扶苏-su2 小时前
Java--获取 Class 类对象
java·开发语言
夜幕下的ACM之路2 小时前
一、基础知识学习(Transformer + 上下文窗口 + Token 计算 + Embedding 向量)
人工智能·学习·transformer·embedding
GHL2842710902 小时前
Base64学习
学习
96772 小时前
C++多线程2 如何优雅地锁门 (lock_guard) 多线程里的锁的种类
java·开发语言·c++
知识分享小能手2 小时前
MongoDB入门学习教程,从入门到精通,MongoDB创建副本集知识点梳理(10)
数据库·学习·mongodb
爱睡懒觉的焦糖玛奇朵3 小时前
【工业级落地算法之人员摔倒检测算法详解】
人工智能·python·深度学习·神经网络·算法·yolo·目标检测
小辉同志3 小时前
78. 子集
算法·leetcode·深度优先
chushiyunen3 小时前
python实现skip-gram(跳词)示例
开发语言·python