国产探花免费观看_亚洲丰满少妇自慰呻吟_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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 泗阳县| 许昌市| 交口县| 德安县| 泰顺县| 博爱县| 广南县| 肇庆市| 怀宁县| 鄂伦春自治旗| 伊吾县| 林周县| 宁德市| 凉城县| 清镇市| 德庆县| 延川县| 界首市| 乡城县| 苏尼特左旗| 青田县| 永定县| 海阳市| 宁德市| 绵阳市| 游戏| 林西县| 彩票| 德庆县| 乌兰浩特市| 西乌珠穆沁旗| 南雄市| 石家庄市| 佳木斯市| 长治县| 柘荣县| 泉州市| 福清市| 汝城县| 黑山县| 建平县|