Python程序:在n步内通过复制粘贴打印最大字符数?


假设我们有一个数字n;我们需要找到在n次操作中可以输入的最大字符数,其中每次操作都类似于

  • 插入字符“x”。

  • 复制所有字符。

  • 粘贴

因此,如果输入为n = 12,则输出将为81。

为了解决这个问题,我们将遵循以下步骤

  • 如果n <= 4,则

    • 返回n

  • v := 6,x := 3,i := 5,j := 0

  • 当i不等于n时,执行

    • v := v + x

    • i := i + 1,j := j + 1

    • 如果j可被3整除,则

      • x := x * 1.5 的整数部分

    • 否则,当j不能被3整除时,则

      • 不做任何操作

    • 否则,

      • x := x * 2

  • 返回v

让我们看看以下实现,以便更好地理解

示例

 在线演示

class Solution:
   def solve(self, n):
      if n <= 4:
         return n

      v = 6
      x = 3
      i = 5
      j = 0
      while i != n:
         v += x
         i += 1
         j += 1

         if j % 3 == 0:
            x = int(x * 1.5)
         elif j % 3 == 1:
            pass
         else:
            x *= 2

      return v

ob = Solution()
n = 12
print(ob.solve(n))

输入

12

输出

81

更新于: 2020年11月10日

73 次浏览

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告