折纸达珠峰高度(for&while循环、闭包函数循环)

对折0.1mm厚度的纸张多少次,高度可达珠峰高度8848180mm。


  (本笔记适合熟悉循环和列表的 coder 翻阅)


【学习的细节是欢悦的历程】


  自学并不是什么神秘的东西,一个人一辈子自学的时间总是比在学校学习的时间长,没有老师的时候总是比有老师的时候多。
            —— 华罗庚


等风来,不如追风去……


对折0.1mm厚度的纸张多少次
折纸达珠峰高度
(高度可达珠峰高度8848180mm)


本文质量分:

97
本文地址: https://blog.csdn.net/m0_57158496/article/details/134168298

CSDN质量分查询入口:http://www.csdn.net/qc


目 录



◆ 折纸达珠峰高度


1、题目描述


1.1 问题截屏


  • 题目描述截屏图片
    在这里插入图片描述
      对折0.1mm厚度的纸张多少次,高度可达珠峰高度8848180mm

1.2 截图“缺陷”


题目来源于 CSDN 问答社区提问“折纸达珠峰高度

  • 题主对循环还不熟咯,要多翻翻书咯
    在这里插入图片描述

      此题目循环次数“不确定”,对于不确凿次数的循环,最是适宜用while关键字构建的循环体。



回页目录


2、算法解析


  • 代码运行效果截屏图片
    在这里插入图片描述
      本题目就是一个循环×2,没得啥子算法讨论。我尝试聊聊用for和while来通过多种代码形式解决。

2.1 题目解析


  • 解析题目,得“挖掘”题意。对于编程解题,“读懂”题目后就得依确定的算法进行数据设计(结构数据)、代码表达,最后才是组织语句输出预期结论。

    1、本题目的纸张对折,对于每次增加的高度来说,就是2的幂次方级别的增加。

    2、还有一点就是,注意小括号里的描述“再对折一次就超过”,如果我们设置的退出循环条件是h >= 8848180,返回值要比当前循环次数少一次,即print(k-1)。

    3、还有一点就是,纸张厚度初值是0.1而不是0。为什么要这么较真哩?因为有可能那0.1,可能影响结果多一次对折。
    在这里插入图片描述



回页目录


2.2 Python 代码(for&2的幂次方)


Python代码(for)


mountQomolangma = 8848180

for i in range(1, int(1e8)): # 对于不确定循环次数,非要用for就搞一个您能想到的大值,反正就是个摆设。我这里设置100w。
    paperHigh = 0.1*2**i + 0.1
    
    if paperHigh >= mountQomolangma:
        break # 

print(f"\n厚度0.1mm的纸张,对折{i}次后高{paperHigh}mm, 对折{i-1}可抵达珠峰高度{mountQomolangma}mm。")


  这样子写代码效率会低,每次循环都在计算2的幂次方,完全可以改用循环×2,效率会更高。



回页目录


2.3 循环×2


循环×2代码


mountQomolangma = 8848180
paperHigh = 0.1

for i in range(1, int(1e8)): # 对于不确定循环次数,非要用for就搞一个您能想到的大值,反正就是个摆设。我这里设置100w。
    paperHigh *= 2
    
    if paperHigh >= mountQomolangma:
        break # 退出循环。

print(f"\n厚度0.1mm的纸张,对折{i}次后高{paperHigh}mm, 对折{i-1}可抵达珠峰高度{mountQomolangma}mm。")


  每次都是×2,用位运算会更快。二进制数左移一位<<1,其表示的数值就翻倍了,也就完成×2操作。



回页目录


2.4 Python位运算<<1替代×2


位运算<<1替代×2代码


mountQomolangma = 8848180
paperHigh = 1

for i in range(1, int(1e8)): # 对于不确定循环次数,非要用for就搞一个您能想到的大值,反正就是个摆设。我这里设置100w。
    paperHigh <<= 1
    
    if paperHigh/10 >= mountQomolangma:
        break # 退出循环。

print(f"\n厚度0.1mm的纸张,对折{i}次后高{paperHigh}mm, 对折{i-1}可抵达珠峰高度{mountQomolangma}mm。")




回页目录


2.5 简洁的while


  还是while循环,代码简洁点,if条件直接放while关键字后做开关就可以。


简洁的while代码


mountQomolangma = 8848180
paperHigh = 1
k = 0

while paperHigh/10 < mountQomolangma:
    k += 1
    paperHigh <<= 1

print(f"\n厚度0.1mm的纸张,对折{k}次后高{paperHigh/10}mm, 对折{k-1}可抵达珠峰高度{mountQomolangma}mm。")



回页目录


2.6 函数自调用(闭包)循环


  不用for和while关键字,可不可以实现循环。答案是肯定的。在python中有一种叫“闭包”的“包”,它能够像递归一样实现数据传递。“闭包”,实际上就是函数的自我调用形成的一个封装的循环空间结构,也就是一层层的“作用域”,数据通过函数参数在各层作用域之间“穿透”。与循环一样,重点在于合理的开关设置,让“闭包”适时“破碎”自恋“回逆”。不然,就真的“进入了万劫不复的轮回”。

  对于闭包的理解,查对于for、while,稍显有点儿不适。对于编程基础弱点,代码能力小些的coder,易读性稍微差那么一点点。但代码结构,依然严谨简洁。


闭包函数实现循环


def fold(h, paper, k):
    
    if (paper+1)/10 < h:
        return fold(h, paper<<1, k+1)
    else:
        print(f"\n厚度0.1mm的纸张,对折{k}次后高{(paper+1)/10}mm, 对折{k-1}可抵达珠峰高度{mountQomolangma}mm。")


if __name__ == '__main__':
    mountQomolangma = 8848180
    fold(mountQomolangma, 1, 0)



回页首


上一篇:  经典循环命题:百钱百鸡(翁五钱一只,母三钱,小鸡三只一钱;百钱百鸡百鸡花百钱)
下一篇: 

我的HOT博:

  本次共计收集 246 篇博文笔记信息,总阅读量 40.46w,平均阅读量 1644。已生成 16 篇阅读量不小于 4000 的博文笔记索引链接。数据采集于 2023-10-12 05:41:03 完成,用时 4 分 41.10 秒。


  1. ChatGPT国内镜像站初体验:聊天、Python代码生成等
    ( 59262 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/129035387
    点赞:126   踩 :0  收藏:798  打赏:0  评论:71
    本篇博文笔记于 2023-02-14 23:46:33 首发,最晚于 2023-07-03 05:50:55 修改。
  2. 让QQ群昵称色变的神奇代码
    ( 58086 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/122566500
    点赞:24   踩 :0  收藏:83  打赏:0  评论:17
    本篇博文笔记于 2022-01-18 19:15:08 首发,最晚于 2022-01-20 07:56:47 修改。
  3. pandas 数据类型之 DataFrame
    ( 9173 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/124525814
    点赞:6   踩 :0  收藏:31  打赏:0  评论:0
    本篇博文笔记于 2022-05-01 13:20:17 首发,最晚于 2022-05-08 08:46:13 修改。
  4. 个人信息提取(字符串)
    ( 7215 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/124244618
    点赞:1   踩 :0  收藏:13  打赏:0  评论:0
    本篇博文笔记于 2022-04-18 11:07:12 首发,最晚于 2022-04-20 13:17:54 修改。
  5. Python列表(list)反序(降序)的7种实现方式
    ( 7161 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/128271700
    点赞:5   踩 :0  收藏:22  打赏:0  评论:8
    本篇博文笔记于 2022-12-11 23:54:15 首发,最晚于 2023-03-20 18:13:55 修改。
  6. 罗马数字转换器|罗马数字生成器
    ( 7035 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/122592047
    点赞:0   踩 :0  收藏:1  打赏:0  评论:0
    本篇博文笔记于 2022-01-19 23:26:42 首发,最晚于 2022-01-21 18:37:46 修改。
  7. Python字符串居中显示
    ( 6966 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/122163023
    点赞:1   踩 :0  收藏:7  打赏:0  评论:1
    本篇博文笔记
  8. 斐波那契数列的递归实现和for实现
    ( 5523 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/122355295
    点赞:4   踩 :0  收藏:2  打赏:0  评论:8
    本篇博文笔记
  9. python清屏
    ( 5108 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/120762101
    点赞:0   踩 :0  收藏:8  打赏:0  评论:0
    本篇博文笔记
  10. 练习:字符串统计(坑:f‘string‘报错)
    ( 5103 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/121723096
    点赞:0   踩 :0  收藏:1  打赏:0  评论:0
    本篇博文笔记
  11. 回车符、换行符和回车换行符
    ( 5093 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/123109488
    点赞:1   踩 :0  收藏:2  打赏:0  评论:0
    本篇博文笔记于 2022-02-24 13:10:02 首发,最晚于 2022-02-25 20:07:40 修改。
  12. 练习:尼姆游戏(聪明版/傻瓜式•人机对战)
    ( 4943 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/121645399
    点赞:14   踩 :0  收藏:42  打赏:0  评论:0
    本篇博文笔记
  13. 密码强度检测器
    ( 4323 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/121739694
    点赞:1   踩 :0  收藏:4  打赏:0  评论:0
    本篇博文笔记于 2021-12-06 09:08:25 首发,最晚于 2022-11-27 09:39:39 修改。
  14. 练习:生成100个随机正整数
    ( 4274 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/122558220
    点赞:1   踩 :0  收藏:6  打赏:0  评论:0
    本篇博文笔记于 2022-01-18 13:31:36 首发,最晚于 2022-01-20 07:58:12 修改。
  15. 我的 Python.color() (Python 色彩打印控制)
    ( 4159 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/123194259
    点赞:2   踩 :0  收藏:8  打赏:0  评论:0
    本篇博文笔记于 2022-02-28 22:46:21 首发,最晚于 2022-03-03 10:30:03 修改。
  16. 罗马数字转换器(用罗马数字构造元素的值取模实现)
    ( 4149 阅读)
    博文地址:https://blog.csdn.net/m0_57158496/article/details/122608526
    点赞:0   踩 :0  收藏:0  打赏:0  评论:0
    本篇博文笔记于 2022-01-20 19:38:12 首发,最晚于 2022-01-21 18:32:02 修改。
推荐条件 阅读量突破三千
(更多热博,请点击蓝色文字跳转翻阅)

回页首


老齐漫画头像

精品文章:

来源:老齐教室


回页首

Python 入门指南【Python 3.6.3】


好文力荐:


CSDN实用技巧博文:


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦幻精灵_cq

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值