华为1000阶台阶问题,每次走一步或者两步或者三步,走一次三步后接下来的一次只能走一步或者两步(即,歇一下),问:如果有1000阶台阶,有多少种走法。。

本文探讨了一道华为面试题的算法实现,针对走三步歇一次的特殊场景进行了详细解析。通过两个函数的巧妙设计,有效地解决了问题,并避免了连续三次走三步的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

作者:非妃是公主
专栏:《笔记》《C++》
个性签:顺境不惰,逆境不馁,以心制境,万事可成。——曾国藩

在这里插入图片描述

上一篇文章解了一下华为面试题,有小伙伴说,有改编的版本为走三步需要歇一次,下次只能走两步或者一部怎么算呢?下面的链接为我的上一篇文章,有一定的关联性,本篇文章,主要是增加了一个限制条件,(即,走三步歇一次);

这里给出链接: 不歇着的情况的详细的解释.

先来看下代码吧:
不歇着的情况:

#include<iostream>
using namespace std;
int number(int n) {
	if (n == 1) {
		return 1;
	}
	else if (n == 2) {
		return 2;
	}
	else if (n == 3) {
		return 4;
	}
	else {
		return number(n - 1) + number(n - 2) + number(n - 3);
	}
}
int main() {
	int n = 1000;
	cin >> n;
	cout << endl << number(n);
}

思路很简单清晰对吗??如果我不歇着,那么就无穷递归就可以了,在上面那个链接里有详细的解释。。

歇着的情况:

#include<iostream>
using namespace std;
int number1(int n);
int number2(int n);
int main() {
	cout << "请输入要走的台阶阶数:";
	int n;
	cin >> n;
	cout << endl << number1(n);
}
int number1(int n) {
	if (n == 1) {
		return 1;
	}
	else if (n == 2) {
		return 2;
	}
	else if (n == 3) {
		return 4;
	}
	else {
		return number1(n - 1) + number1(n - 2) + number2(n - 3); //如果走三步后,下次就不再走三次调用number2()函数
	}
}
int number2(int n) {
	if (n == 1) {
		return 1;
	}
	else if (n == 2) {
		return 2;
	}
	else {
		return number1(n - 1) + number1(n - 2);//如果走三步,下次就不再走三步所以不在递归计算三步的情况
	}
}

但是,我要歇着,那好,我们就加一个限制条件,即,每走一次三步,我们下次递归的时候,就不再包含继续走三次的递归了。

我写了两个函数,number1()函数就是正常递归,但是,当下走三步的情况,即,

else {
		return number1(n - 1) + number1(n - 2) + number2(n - 3); //如果走三步后,下次就不再走三次调用number2()函数
	}

注意:是number2(n-3),而不是number1(n-3),而仔细看number2(int n)会很容易发现,里面递归调用的时候没有(n-3)的情况,这也就自然排除了走三步后,下一次继续走三步的情况。

其实,说白了就是两个函数交叉调用,走一步或两步,我就递归调用number1(int n);走三步,我就调用number2(int n),即下一次只能走一次或者两次。而重要的是在number2(int n)中,我继续调用number1(),还是可以走三步。‘

这样就限制了走三步歇一次的这个条件。

欢迎评论区指正,谢谢!!

如果你觉得还可以,也可以点个赞,当作是一个鼓励吧!谢谢!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cherries Man

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值