C++自存错题(13)数楼梯(高精度)
楼梯有 N 阶,上楼可以一步上一阶,也可以一步上二阶。
编一个程序,计算共有多少种不同的走法。
输入格式
一个数字,楼梯数。
输出格式
输出走的方式总数。
输入输出样例
输入 #1复制
4
输出 #1复制
5
说明/提示
对于 60% 的数据,N≤50;
对于 100% 的数据,1≤N≤5000。
#include<iostream>
#include<algorithm>
using namespace std;
int arr[5003][5003];
int main(){
arr[1][1] = 1;
arr[2][1] = 2;
int n;
int len = 1;
int g = 0;
cin >> n;
for (int i =3 ; i <= n; i++) {
for (int j = 1; j <= len; j++) {
arr[i][j] = arr[i - 1][j] + arr[i - 2][j] + g;
g = 0;
if (arr[i][j] >= 10) {
g = arr[i][j] / 10;
arr[i][j] = arr[i][j] % 10;
if (g) {
len++;
}
}
}
}
for (int j = len; j > 0; j--) {
cout << arr[n][j];
}
return 0;
}
编一个程序,计算共有多少种不同的走法。
输入格式
一个数字,楼梯数。
输出格式
输出走的方式总数。
输入输出样例
输入 #1复制
4
输出 #1复制
5
说明/提示
对于 60% 的数据,N≤50;
对于 100% 的数据,1≤N≤5000。
#include<iostream>
#include<algorithm>
using namespace std;
int arr[5003][5003];
int main(){
arr[1][1] = 1;
arr[2][1] = 2;
int n;
int len = 1;
int g = 0;
cin >> n;
for (int i =3 ; i <= n; i++) {
for (int j = 1; j <= len; j++) {
arr[i][j] = arr[i - 1][j] + arr[i - 2][j] + g;
g = 0;
if (arr[i][j] >= 10) {
g = arr[i][j] / 10;
arr[i][j] = arr[i][j] % 10;
if (g) {
len++;
}
}
}
}
for (int j = len; j > 0; j--) {
cout << arr[n][j];
}
return 0;
}
全部评论
相关推荐
程序员牛肉:我靠你这个实习经历其实最需要担心的点是你做的太多了,可能会被面试官怀疑是你伪造的。
交易状态机是你做的,支付多渠道是你做的,对账是你做的,结算还是你做的,重复支付也是你做的,整个服务的异常处理也是你做的。
其实你这个反而问题很大的,你想想站在面试官的角度,他是真的会相信你的能力很强,还是相信这份实习你伪造了大部分?我相信你真的做了这么多,但是删一些,废话删一删。你这个做的太多了反而真实性不可信。
后面再补一个项目,在github上找一个高star的项目学一学然后写到自己简历上。我觉得你能力肯定没问题。28届能做到这个份上很厉害,但是在求职市场中,你不是在跟28届的同学比,把你这个简历放到27届其实也就一般水平。
所以后续要想一想看看能不能给自己简历上搞点亮点,比如开源贡献呢?比如博客呢?
点赞 评论 收藏
分享
查看20道真题和解析