爬楼梯算法 bug 容易被忽视的变量越界
问题回顾:
现在一共有n阶楼梯,你可以一次跨1节楼梯,也可以一次跨2节,给出跨n节楼梯的总的方法数。1<=n<=50.
例1:
输入: 5
输出: 8
例2:
输入: 1
输出: 1
我自己写了一个程序,结果前38节楼梯的结果都是对的,从第39节楼梯开始出错。不知何故?
我的程序:
#include<iostream> using namespace std; long long C_a_b(int a, int b) { int i_for, a_; long long temp1 = 1, temp2 = 1; a_ = a; for (i_for = 0; i_for < a; i_for++) { temp1 *= b; b -= 1; } for (i_for = 0; i_for < a_; i_for++) { temp2 *= a; a -= 1; } return (temp1 / temp2); } int main() { long long answer = 1; int n, m_max; int i_for; cin >> n; m_max = n / 2; for (i_for = 1; i_for < m_max + 1; i_for++) { answer += C_a_b(i_for, n - i_for); } cout << answer << endl; cin >> n; return 0; }
正确的结果的代码:
#include<iostream> using namespace std; int main() { int i_for,length; cin >> length; long long *data=new long long[length]; data[0] = data[1] = 1; data[2] = 2; for (i_for = 3; i_for < length; i_for++) { data[i_for] = data[i_for - 1] * 2 - data[i_for - 3]; } cout << data[length - 1] << endl; delete []data; return 0; }
我就郁闷了,前面38个台阶爬的好好地,为什么到了第39个台阶就不行了?果然程序还是要简洁点好吗!!!
这个bug先整理出来放在这里。
下面几张图是调试截图:
总结:
程序产生的中间变量不能太大。简单易行的算法才是好算法!!!!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· 不到万不得已,千万不要去外包
· C# WebAPI 插件热插拔(持续更新中)
· .NET 9 new features-C#13新的锁类型和语义
· 会议真的有必要吗?我们产品开发9年了,但从来没开过会
· 《SpringBoot》EasyExcel实现百万数据的导入导出