张德长

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

爬楼梯问题的三种算法测试

爬楼梯问题,有n阶楼梯,每一步可以爬一个台阶或者2个台阶,总的爬法数?

例如1个台阶,1种爬法1;f(1)=1

例如2个台阶,2种爬法1+1,2;f(2)=2

例如3个台阶,3种爬法1+1+1,2+1,1+2;f(3)=f(2)+f(1)

例如4个台阶,5种爬法1+1+1+1,2+1+1,1+2+1,1+1+2,2+2;f(4)=f(3)+f(2)

......

例如n个台阶,爬法f(n)f(n-1)+f(n-2)

先看下运算结果:

楼梯个数=10
递归法:    结果=89  耗时=16 Ticks
字典递归法:    结果=89  耗时=337 Ticks
循环法:    结果=89  耗时=3 Ticks

楼梯个数=20
递归法:    结果=10946  耗时=1500 Ticks
字典递归法:    结果=10946  耗时=23 Ticks
循环法:    结果=10946  耗时=2 Ticks

楼梯个数=30
递归法:    结果=1346269  耗时=185763 Ticks
字典递归法:    结果=1346269  耗时=104 Ticks
循环法:    结果=1346269  耗时=3 Ticks

楼梯个数=40
递归法:    结果=165580141  耗时=23378518 Ticks
字典递归法:    结果=165580141  耗时=58 Ticks
循环法:    结果=165580141  耗时=3 Ticks

楼梯个数=50
递归法:    结果=-1109825406  耗时=2842699468 Ticks
字典递归法:    结果=-1109825406  耗时=148 Ticks
循环法:    结果=-1109825406  耗时=3 Ticks

 

递归法,时间复杂度O(n2),性能最差,

字典递归法,时间复杂度O(n),性能较好,需要进行字典数据查找和读写

循环法时间复杂度O(n),性能最好

三种算法

//简单的递归算法
public static int UpStairInteration(int n)
{
if (n == 1) return 1;
if (n == 2) return 2;
return UpStairInteration(n - 1) + UpStairInteration(n - 2);
}
//递归+字典算法
public static int UpStairDictionary(int n, Dictionary<int, int> upStairDic)
{
if (n == 1) return 1;
if (n == 2) return 2;
if (upStairDic.ContainsKey(n)) return upStairDic[n];
int result = UpStairDictionary(n - 1, upStairDic) + UpStairDictionary(n - 2, upStairDic);
upStairDic.Add(n, result);
return result;
}
//循环算法
public static int UpStairFor(int n)
{
if (n == 1) return 1;
if (n == 2) return 2;
int result = 0;
int p = 2, pp = 1;
for (int i = 3; i <= n; i++)
{
result = p + pp;
pp = p;
p = result;
}
return result;
}

测试

static void test8()
{
UpStairTest(1);
for (int i = 10; i <= 100; i += 10)
{
UpStairTest(i);
}
}
static void UpStairTest(int n)
{
Dictionary<int, int> upStairDic = new Dictionary<int, int>();
Console.WriteLine($"楼梯个数={n}");
int result = 0;
Stopwatch watch = new Stopwatch();
watch.Start(); watch.Stop();
watch.Restart();
result = UpStairInteration(n);
watch.Stop();
Console.WriteLine($"递归法: 结果={result} 耗时={watch.ElapsedTicks} Ticks");
watch.Restart();
result = UpStairDictionary(n, upStairDic);
watch.Stop();
Console.WriteLine($"字典递归法: 结果={result} 耗时={watch.ElapsedTicks} Ticks");
watch.Restart();
result = UpStairFor(n);
watch.Stop();
Console.WriteLine($"循环法: 结果={result} 耗时={watch.ElapsedTicks} Ticks");
Console.WriteLine();
}

运行结果

posted on   张德长  阅读(638)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示