橙子是只喵 2021-10-25 14:28 采纳率: 100%
浏览 53
已结题

Python 求最大幂次,用while循环

编写一个程序,从键盘输入一个正整数M(2 < M <1000000),求解并依次输出符合下面条件的最大幂次n以及21 + 22 + 23 + ... + 2n的值:

21 + 22 + 23 + ...+ 2n<M

【输入形式】

输入共1行,为正整数M;

【输出形式】

输出共2行,

  1. 1行为符合条件的最大整数n
  2.     第2行为21 + 22 + 23 + ...+ 2n的和值。
    

【样例输入】

5

【样例输出】

1

2

  • 写回答

1条回答 默认 最新

  • -Undefined_ 2021-10-25 14:43
    关注
    m=int(input())
    s=0
    n=1
    while s<m:
        s+=pow(2,n)
        n+=1
    print(n-2,s-pow(2,n-1),sep='\n')
    

    觉得有用的话采纳一下哈

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月25日
  • 已采纳回答 10月25日
  • 创建了问题 10月25日

悬赏问题

  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因