首页 > 编程语言 > 详细

动态规划算法例题

时间:2018-12-23 20:32:49      阅读:143      评论:0      收藏:0      [点我收藏+]

1. 走台阶问题

有n级台阶,一个人每次上一级或者两级,问有多少种走完n级台阶的方法?

方法1:递归

#include <iostream>
using namespace std;

const int N = 100; //假设最多走100级台阶
int result[N]; //保存结果

int step(int n)
{
if(n > 2)
{
result[n] = step(n-1) + step(n-2);
}
return result[n];
}

int main()
{
int n;
cin >> n;
result[1] = 1;
result[2] = 2;
cout << step(n) << endl;
system("pause");
return 0;
}

方法2:自底向上

#include <iostream>
using namespace std;

const int N = 100; //假设最多走100级台阶
int result[N]; //保存结果

int step(int n)
{
for(int i = 3; i <= n; i++)
{
result[i] = result[i-1] + result[i-2];
}
return result[n];
}

int main()
{
int n;
cin >> n;
result[1] = 1;
result[2] = 2;
cout << step(n) << endl;
system("pause");
return 0;
}

2. 求斐波拉契数列Fibonacci

方法1:递归

#include <iostream>
using namespace std;

const int N = 101; //假设最多求到100
int result[N]; //保存结果

int fb(int n)
{
if(n >= 2)
{
result[n] = fb(n-1) + fb(n-2);
}
return result[n];
}

int main()
{
int n;
cin >> n;
result[0] = 0;
result[1] = 1;
cout << fb(n) << endl;
system("pause");
return 0;
}

方法2:自底向上

#include <iostream>
using namespace std;

const int N = 101; //假设最多求到100
int result[N]; //保存结果

int fb(int n)
{
for (int i = 2; i <= n; i++)
{
result[i] = result[i-1] + result[i-2];
}
return result[n];
}

int main()
{
int n;
cin >> n;
result[0] = 0;
result[1] = 1;
cout << fb(n) << endl;
system("pause");
return 0;
}

动态规划算法例题

原文:https://www.cnblogs.com/mengjuanjuan/p/10165389.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!