阿育王 发表于 2022-4-24 23:49:34

python杨辉三角问题

          1
         / \
      1   1
       / \ / \
      1   2   1
   / \ / \ / \
    1   3   3   1
   / \ / \ / \ / \
1   4   6   4   1
/ \ / \ / \ / \ / \
1   5   10105   1
把每一行看做一个list,试写一个generator,不断输出下一行的list:

# -*- coding: utf-8 -*-

def triangles():
        此处写代码,没思路!!



# 期待输出:
#
#
#
#
#
#
#
#
#
#
n = 0
results = []
for t in triangles():
    results.append(t)
    n = n + 1
    if n == 10:
      break

for t in results:
    print(t)

if results == [
    ,
    ,
    ,
    ,
    ,
    ,
    ,
    ,
    ,
   
]:
    print('测试通过!')
else:
    print('测试失败!')

傻眼貓咪 发表于 2022-4-25 08:35:32

def triangles():
        res = []
        while True:
                if len(res) < 2:
                        res.append(1)
                else:
                        temp =
                        for i in range(1, len(res)):
                                temp.append(res + res)
                        temp.append(1)
                        res = temp
                yield res

for n, i in enumerate(triangles()):
        if n > 10: # 预设想输出多少行,不然无限输出
                break
        print(i)

Stubborn 发表于 2022-4-25 09:18:35

本帖最后由 Stubborn 于 2022-4-25 09:32 编辑

思路?给定你任意一个状态 Ni , 假如Ni为 ,,你将如何生成下一个状态Ni+1 ,并确保所有状态通用?
Ni =
r =   
R =   
或者
res = )]
res.append(1)
res.insert(0, 1)


另外你应该知道如何编写generator吧?


wp231957 发表于 2022-4-25 10:07:04

Stubborn 发表于 2022-4-25 09:18
思路?给定你任意一个状态 Ni , 假如Ni为 ,,你将如何生成下一个状态Ni+1 ...

麻烦看看这个代码是否还有优化的地方:
网上看到的最NB的代码 是 使用推导式   一个中括号搞定杨辉三角
我这个代码 咋糅合也 变不成一句代码
def f(a):
    n=
    yield n
    for x in range(a):
      n.append(0)
      n.insert(0,0)
      n= for idx,value in enumerate(n) if idx<len(n)-1]
      yield n

a=f(10)
for x in a:
    print(x)

'''











'''   

Stubborn 发表于 2022-4-25 10:40:55

本帖最后由 Stubborn 于 2022-4-25 10:55 编辑

wp231957 发表于 2022-4-25 10:07
麻烦看看这个代码是否还有优化的地方:
网上看到的最NB的代码 是 使用推导式   一个中括号搞定杨辉三角,你看到的什么样的
...

一般都是根据上一个状态,推导下一个状态的呀

def gen(n):
    yield
    yield
    r =
    while n:
      r = + )] +
      yield r
      n -= 1

qq1151985918 发表于 2022-4-25 12:37:28

wp231957 发表于 2022-4-25 10:07
麻烦看看这个代码是否还有优化的地方:
网上看到的最NB的代码 是 使用推导式   一个中括号搞定杨辉三角
...

一行没能实现,两行OK不
f = lambda a,b:1 if a==b or b==0 else f(a-1,b)+f(a-1,b-1)
print([ for x in range(10)])

傻眼貓咪 发表于 2022-4-25 15:39:33

太厉害了,大佬们的代码让我大开眼界。

wp231957 发表于 2022-4-27 09:50:22

qq1151985918 发表于 2022-4-25 12:37
一行没能实现,两行OK不

又去查看了当初浏览的网页,有些记忆错误
代码虽然都很短,但是常规算法都是先写了一个函数,然后才是一行输出,这和你的没啥区别

真正的一行输出   是引用了三方库
页: [1]
查看完整版本: python杨辉三角问题