isdkz 发表于 2022-3-17 19:07:46

python编程题

函数 main() 接收一个大于等于 1 的正整数 n 和 一个介于 区间的正整数 a ,

要求返回表达式 a+aa+aaa+aaaa+...+aa...aa 前n项的和。例如,当 n=3 和 a=1 时,

计算 1+11+111,返回 123。

请完成 main(n,a) 函数的编写,要求不能使用循环结构,不能使用推导式。

qq1151985918 发表于 2022-3-17 19:07:47

def main(n, a):
    func = lambda x: int(str(a) * x)
    s = sum(map(func, range(1, n + 1)))
    return s
   
if __name__ == "__main__":
    print(main(3, 1))

ba21 发表于 2022-3-17 19:23:24

那就是递归了。

def main(n, a):
    if n==1:
      return a
    else:
      return int(n*str(a))+main(n-1, a)

print(main(3, 2))
      

      

傻眼貓咪 发表于 2022-3-17 19:27:27

递归:def func(n, a, c = ""):
    if(len(a) > n): return 0
    x = int(a)
    if(not c):
      c = a
    return x + func(n, a + c, c)

n = 3
a = 1

print(func(n, str(a)))

isdkz 发表于 2022-3-17 19:46:22

本帖最后由 isdkz 于 2022-3-17 19:55 编辑

傻眼貓咪 发表于 2022-3-17 19:27
递归:

谢谢大佬,不过题目要求传入的 n 和 a 都为整数。

isdkz 发表于 2022-3-17 19:52:22

ba21 发表于 2022-3-17 19:23
那就是递归了。

谢谢大佬,不过我提交了答案就后它出现了一个题目上没出现的要求:



这 map 函数要怎么用呀,实在想不出来了{:5_96:} ,

忘大佬解惑

python爱好者. 发表于 2022-3-17 20:17:51

isdkz 发表于 2022-3-17 19:52
谢谢大佬,不过我提交了答案就后它出现了一个题目上没出现的要求:




有点为了需求强制转换的意思了......eee....{:10_260:}
def main(n,a):
    while True:
      if n >= 1:
            yield int(str(a) * n)
            n -= 1
      else:
            break

print(sum(list(map(lambda x:x,main(3,1)))))

isdkz 发表于 2022-3-17 20:22:48

python爱好者. 发表于 2022-3-17 20:17
有点为了需求强制转换的意思了......eee....

谢谢大佬,但是他是让编写 main 函数里面的代码,

函数是供他那边调用的,所以返回值肯定也不能是 迭代器

isdkz 发表于 2022-3-17 21:33:16

qq1151985918 发表于 2022-3-17 20:59
def main(n, a):
    func = lambda x: int(str(a) * x)
    s = sum(map(func, range(1, n + 1)))


谢谢大佬,大佬牛逼{:5_106:}

歌者文明清理员 发表于 2023-8-11 01:19:44

考古{:10_256:}

陶远航 发表于 2023-8-25 11:07:26

考古{:10_256:}
页: [1]
查看完整版本: python编程题