国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python解決N階臺階走法問題的方法分析

2020-02-16 11:21:31
字體:
來源:轉載
供稿:網友

本文實例講述了Python解決N階臺階走法問題的方法。分享給大家供大家參考,具體如下:

題目:一棟樓有N階樓梯,兔子每次可以跳1、2或3階,問一共有多少種走法?

Afanty的分析:

遇到這種求規律的問題,自己動動手推推就好,1階有幾種走法?2階有幾種走法?3階有幾種走法?4階有幾種走法?5階有幾種走法?

對吧,規律出來了!

易錯點:這不是組合問題,因為第1次走1階、第2次走2階不同于 第1次走2階、第2次走1階

下面是Python的遞歸實現代碼:

def allMethods(stairs):  '''''  :param stairs:the numbers of stair  :return:  '''  if isinstance(stairs,int) and stairs > 0:    basic_num = {1:1,2:2,3:4}    if stairs in basic_num.keys():      return basic_num[stairs]    else:      return allMethods(stairs-1) + allMethods(stairs-2) + allMethods(stairs-3)  else:    print 'the num of stair is wrong'    return False

當然也可以用非遞歸的方法來實現,下面就是基于遞推法的代碼:

def allMethod(stairs):  '''''遞推實現  :param stairs: the amount of stair  :return:  '''  if isinstance(stairs,int) and stairs > 0:    h1,h2,h3,n = 1,2,4,4    basic_num = {1:1,2:2,3:4}    if stairs in basic_num.keys():      return basic_num[stairs]    else:      while n <= stairs:        temp = h1        h1 = h2        h2 = h3        h3 = temp + h1 + h2      return h3  else:    print 'the num of stair is wrong'    return False

好的,以上就是分別用了遞歸和遞推法實現的過程。

更多關于Python相關內容感興趣的讀者可查看本站專題:《Python數據結構與算法教程》、《Python加密解密算法與技巧總結》、《Python編碼操作技巧總結》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經典教程》

希望本文所述對大家Python程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 商都县| 滦南县| 兴宁市| 正阳县| 江川县| 新绛县| 陆川县| 龙门县| 洪湖市| 灌云县| 广宗县| 玉龙| 宿州市| 万年县| 山阴县| 崇礼县| 潼南县| 太仓市| 民勤县| 丰县| 东乡| 莱州市| 台江县| 广灵县| 蒙城县| 西充县| 江油市| 咸丰县| 阿克苏市| 平陆县| 资阳市| 惠安县| 大化| 山东省| 余姚市| 仁化县| 仁化县| 三门峡市| 电白县| 六枝特区| 会泽县|