[OJ]走楼梯2(C++,DP)
创始人
2025-05-29 23:57:08
0

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

但你不能连续三步都走两阶,计算走到第nnn阶共有多少种不同的走法。

输入格式

一行,一个数字,表示nnn。

输出格式

输出走楼梯的方式总数。

样例输入

6

样例输出

12

数据规模

对于100100%100的数据,保证n≤50n≤50n≤50。

解题思路:

需要遍历每一种情况,很容易想到DP

如果没有限制“不能连续三步都走两阶”,本题就是简单的兔子数列

dp[0] = 1;//简单的初始化条件,台阶数为0,只有一种可能for (int i = 1; i <= max_step; i++)dp[i] = dp[i - 1] + dp[i - 2];

多了限制,自然就少了可能

那么尝试用排除法

需要排除走666、888、101010、141414、.........,显然需要排除的情况太多了

所以我们采用正难则反的思路,正面求解

对于每一步,我们有三种选择(只有三种情况,不难证明):111、222、444

但是需要考虑限制,所以有以下几种情况

(1)当前走了111步,到达此处的方式不受限制

(2)当前走了222步,所以我们只能通过走111步的方式到达此处

(3)当前走了444步,所以我们只能通过走111步的方式到达此处

很简单,于是我们根据这个思路写出代码

int dp[max_step + 1] = { 0 };//存储数据含义:到达当前位置之后的可能数
bool disable[max_step + 1][3] = { false };//限制标记
int step[3] =  { 1,2,4 };dp[0] = 1;//简单的初始化条件,台阶数为0,只有一种可能for (int i = 1; i <= max_step; i++) {for (int j = 0; j < 3; j++) {if (!disable[i - step[j]][j]) {dp[i] += dp[i - step[j]];if (j != 0) disable[i][1] = disable[i][2] = true;//只能通过走1步的方式到达}}
}

结束了?当然没有,这个思路是有一点瑕疵的

假如当前有444级台阶,有几种方法?

很快你就会回答有555种,但是计算机会回答有444种

那么是哪一种可能性被漏掉了呢?

1 1 1 1
2 1 1
1 2 1
1 1 2
2 2

是第三种可能消失了

因为我们被禁止跳222级台阶到达dp[2],但是这不是应该被禁止的吗?

我们要禁止的是跳222级、跳444级连续选择

但是上面的方法会导致跳222级之后跳111级的可能也被去除了,所以我们修改代码,把跳1,2,41, 2, 41,2,4级的情况分开存储

int dp[max_n + 1][3];//存储的数据含义:以方式j到达当前位置之后的可能数
int step[3] = { 1,2,4 };dp[0][0] = dp[0][1] = dp[0][2] = 1;for (int i = 1; i <= max_step; i++) {for (int j = 0; j < 3; j++) {dp[i][0] += dp[i - step[j]][j];if (j == 1) dp[i][j] += dp[i - step[0]][0];else if (j == 2) dp[i][j] += dp[i - step[0]][0];}
}

最后,AC代码如下

#include 
#include 
using namespace std;
const int max_n = 50;
const int bias = 4;//加上偏置量,防止数组越界long long dp[max_n + 1 + bias][3];
int step[3] = { 1,2,4 };int main() {int n;cin >> n;dp[0 + bias][0] = dp[0 + bias][1] = dp[0 + bias][2] = 1;for (int i = 1 + bias; i <= n + bias; i++) {for (int j = 0; j < 3; j++) {dp[i][0] += dp[i - step[j]][j];if (j == 0) {dp[i][1] += dp[i - step[j]][j];dp[i][2] += dp[i - step[j]][j];}}}cout << dp[n + bias][0];return 0;
}

相关内容

热门资讯

阿联酋最大银行及另两家中东银行... 观点网讯:5月8日,路透社报道指,阿联酋最大银行第一阿布扎比银行(First Abu Dhabi B...
深圳239亿地王易主,再造万象... 2017年,世茂集团豪掷239.43亿元拿下世茂深港国际中心地块,曾规划建筑高度达700米的深圳第一...
蔚来在安庆成立新能源科技公司 ... 天眼查App显示,近日,安庆蔚来新能源科技有限公司成立,法定代表人为姚蒀,注册资本500万人民币,经...
美国牛肉商期盼峰会重启对华出口 据路透社5月8日报道,美国牛肉生产商正期待特朗普与中国于5月14日至15日的峰会推动对华出口许可恢复...
创业板首家未盈利企业,市值突破... 5月8日,大普微总市值正式突破2000亿元大关。截至午间收盘,大普微涨14.07%,报493.1元/...
招商证券:董事长霍达因工作变动... 招商证券公告,公司董事长霍达因工作变动申请辞去董事长、执行董事等全部职务,辞任自辞呈送达董事会之日生...
原创 中... 【阅读须知】本文所引用的所有信息和数据,均为作者通过查阅官方资料与网络公开数据整理、分析而成,旨在为...
原创 从... 2026年5月5日,中国商务部发布了一项具有划时代意义的专项阻断禁令,这份公告让一向倚仗长臂管辖的美...
布米普特拉北京投资基金管理有限... 美国圣路易斯联邦储备银行总裁穆萨莱姆周三发出明确信号,美联储货币政策面临的潜在风险正在发生关键转向。...
加工的秘密:超精加工设备如何做... 你知道吗? 一根头发丝的直径大约0.07毫米,也就是70微米。 超精加工设备,可切出表面,其尺寸为0...
招商证券董事长霍达因工作变动离... 北京商报讯(记者 刘宇阳 实习生 王思奕)5月8日,招商证券发布关于公司董事长离任暨推举董事代行董事...
华帝股份营收创近3年新低,37... 乐居财经李兰近日,华帝股份(002035.SZ)发布2025年年度报告。 2025年,华帝股份实现营...
大模型融资杀疯了!月之暗面狂揽... 图源:视觉中国 5月7日,据华峰资本官微消息,国内头部大模型公司月之暗面(Kimi)于近日完成新一轮...
扎根长宁二十余载,仲利国际融资... 作为总部扎根上海长宁的优质台资金融企业,仲利国际融资租赁有限公司深耕融资租赁行业二十余载,始终坚守金...
估值210亿!李彦宏又将收获一... 来源:直通IPO,文/王非 国产GPU上市潮仍然汹涌,继两家登陆A股、两家登陆H股后,这家公司正推进...
基金“盲盒”拆了 公募基金正在迎来一场让投资者“看得懂”的变革。 近日,华夏、易方达、南方、招商等12家头部及特色基金...
原创 2... 前言 十年间,中国企业在印尼镍产业链累计砸下超过140亿美元,电厂、公路、码头和全套生产线,硬生生...
原创 欧... 俄罗斯卫星通讯社5月6日报道,欧盟宣布禁止欧洲银行为含有来自不可靠供应商的关键部件的可再生能源项目提...
原创 余... 2026年5月2日,在中国理财市场扎根十三年的余额宝,终于触碰到了一个让所有人错愕的数字——7日年化...
银华基金增聘谭普景共同管理银华... 来源:新浪基金∞工作室 5月8日,银华基金管理股份有限公司发布公告称,为银华中证机器人交易型开放式指...