免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: 陈良乔
打印 上一主题 下一主题

[算法] 求证一个算法题目,小兔子上10楼一共有多少种方法 [复制链接]

论坛徽章:
11
摩羯座
日期:2013-09-16 11:10:272015亚冠之阿尔萨德
日期:2015-06-12 22:53:29午马
日期:2014-04-15 11:08:53亥猪
日期:2014-03-02 23:46:35申猴
日期:2013-12-06 22:07:00亥猪
日期:2013-11-28 12:03:13双鱼座
日期:2013-11-21 14:43:56亥猪
日期:2013-10-23 10:55:49处女座
日期:2013-10-17 18:15:43午马
日期:2013-09-27 17:40:4215-16赛季CBA联赛之青岛
日期:2016-06-22 00:45:55
31 [报告]
发表于 2012-10-27 21:52 |只看该作者
本帖最后由 Ager 于 2012-10-27 21:54 编辑
zylthinking 发表于 2012-10-27 21:50
规律想了以下, 恩, 应该是无误的, 所谓到达第10层的方法数, 其实就是等于到达 7, 8, 9 层的方法数, 最 ...




对,就是这个方法!

所以我说是“算术”,就是最最简单的加法。(所以,最好用线性的方法,老老实实地做加法,挨个更新数组元素。)千万不要用函数做,更不要用递归!





论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
32 [报告]
发表于 2012-10-27 21:59 |只看该作者
回复 27# Ager


   
从小爱犯这种错

论坛徽章:
11
摩羯座
日期:2013-09-16 11:10:272015亚冠之阿尔萨德
日期:2015-06-12 22:53:29午马
日期:2014-04-15 11:08:53亥猪
日期:2014-03-02 23:46:35申猴
日期:2013-12-06 22:07:00亥猪
日期:2013-11-28 12:03:13双鱼座
日期:2013-11-21 14:43:56亥猪
日期:2013-10-23 10:55:49处女座
日期:2013-10-17 18:15:43午马
日期:2013-09-27 17:40:4215-16赛季CBA联赛之青岛
日期:2016-06-22 00:45:55
33 [报告]
发表于 2012-10-27 22:01 |只看该作者
本帖最后由 Ager 于 2012-10-27 22:08 编辑
zylthinking 发表于 2012-10-27 21:50
规律想了以下, 恩, 应该是无误的, 所谓到达第10层的方法数, 其实就是等于到达 7, 8, 9 层的方法数, 最后都是一步到达第十层


是的。

所以,可以推广开来,如果小兔子有N种蹬步法(就是一次能上多少阶的“小方法数”),那么,求上指定T阶的总方法的total(“大方法数”)就是:构造长度不少于T的数列:数列中每一项等于它前面的连续N项之和(项不够,用0凑)。






论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
34 [报告]
发表于 2012-10-27 22:14 |只看该作者
回复 31# Ager


    递归也是可以的,不过诀窍是把递归变成“尾调用”,比如说这样:
  1. local function solve(n)
  2.     local function _rec(n, n_3, n_2, n_1)
  3.         if n == 0 then
  4.             return n_1
  5.         else
  6.             return _rec(n-1, n_2, n_1, n_1+n_2+n_3)
  7.         end
  8.     end
  9.     return _rec(n, 0, 0, 1)
  10. end
复制代码

论坛徽章:
2
亥猪
日期:2014-03-19 16:36:35午马
日期:2014-11-23 23:48:46
35 [报告]
发表于 2012-10-27 22:25 |只看该作者
@Ager

你误会我说的母函数了,其实就是生成函数或者说递推公式,28L那个整理出来就是母函数嘛

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
36 [报告]
发表于 2012-10-27 22:29 |只看该作者
回复 35# gvim


    那个只能算母函数的系数数列……可以参看这篇:

http://www.matrix67.com/blog/archives/120

论坛徽章:
6
寅虎
日期:2013-10-10 21:59:16狮子座
日期:2013-11-12 09:24:41金牛座
日期:2013-12-14 17:02:23酉鸡
日期:2014-01-16 12:34:37技术图书徽章
日期:2014-02-15 12:52:31巨蟹座
日期:2014-05-17 14:09:52
37 [报告]
发表于 2012-10-27 22:30 |只看该作者
这个东东用来说明如何将递归转为秩代,是个好例子,比阶乘要好。

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
38 [报告]
发表于 2012-10-27 22:34 |只看该作者
本帖最后由 windoze 于 2012-10-27 22:40 编辑

回复 9# Ager

这个数列的递推公式是
f(n)=f(n-1)+f(n-2)+f(n-3)

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
39 [报告]
发表于 2012-10-27 22:41 |只看该作者
本帖最后由 starwing83 于 2012-10-27 22:41 编辑

这里有个很好的网站,可以轻松找出任何已知的序列的一些信息:http://oeis.org/A000073

楼主的序列是三斐波拉契数列= =我也不知道那个词怎么翻译= =tribonacci

这儿有个通项公式:a(n) = 3*c*((1/3)*(a+b+1))^n/(c^2-2*c+4) where a=(19+3*sqrt(33))^(1/3), b=(19-3*sqrt(33))^(1/3), c=(586+102*sqrt(33))^(1/3). The offset is 1. a(3)=2. Round off to the nearest integer. [Al Hakanson (hawkuu(AT)gmail.com), Feb 02 2009]

别问我,我没看懂这玩意儿到底怎么算……

还给出一个Python的代码:
(Python)
def a(n, adict={0:0, 1:0, 2:1}):
.if n in adict:
..return adict[n]
.adict[n]=a(n-1)+a(n-2)+a(n-3)
.return adict[n] #- David Nacin, Mar 07 2012


简而言之:这网站就是一装逼利器啊……

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
40 [报告]
发表于 2012-10-27 23:05 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP