题目传送门
一、递推+高精度
#include <bits/stdc++.h>
using namespace std;
const int N = 5010;
vector<int> add(vector<int> &A, vector<int> &B) {
if (A.size() < B.size()) return add(B, A);
int t = 0;
vector<int> C;
for (int i = 0; i < A.size(); i++) {
t += A[i];
if (i < B.size()) t += B[i];
C.push_back(t % 10);
t /= 10;
}
if (t) C.push_back(t);
return C;
}
int main() {
int n;
cin >> n;
if (n <= 2) {
printf("%d", n);
return 0;
}
vector<int> A, B, C;
A.push_back(1);
B.push_back(2);
for (int i = 3; i <= n; i++) {
C = add(A, B);
A.assign(B.begin(), B.end());
B.assign(C.begin(), C.end());
}
for (int i = B.size() - 1; i >= 0; i--)printf("%d", B[i]);
return 0;
}
二、深度优先【无法AC】
#include <bits/stdc++.h>
using namespace std;
int n;
int ways;
void dfs(int level) {
if (level == n) ways++;
for (int i = 1; i <= 2; i++)
if (level + i <= n) dfs(level + i);
}
int main() {
cin >> n;
dfs(0);
printf("一共 %d 种方法。\n", ways);
return 0;
}
三、深度优先+输出路径【无法AC】
#include <bits/stdc++.h>
using namespace std;
const int N = 110;
int a[N];
int n;
int ways;
void dfs(int level, int step) {
if (level == n) {
ways++;
for (int i = 0; i < step; i++)printf("%d\t", a[i]);
printf("\n");
}
for (int i = 1; i <= 2; i++) {
if (level + i <= n) {
a[step] = i;
dfs(level + i, step + 1);
}
}
}
int main() {
cin >> n;
dfs(0, 0);
printf("一共 %d 种方法。\n", ways);
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!