Crie um triângulo de Pascal que seja uma lista aninhada e contenha zeros nos pontos não utilizados.
Na matriz de saída, os números do Triângulo de Pascal são separados por zeros e preenchidos por zeros em cada lado, para que sejam centralizados. Por exemplo, a linha inferior (última sub-matriz) não deve ter zeros à esquerda e à direita; o segundo e último sub-array possui um preenchimento zero em cada lado e assim por diante.
Aqui está a saída para entrada 5
:
[[0,0,0,0,1,0,0,0,0],
[0,0,0,1,0,1,0,0,0],
[0,0,1,0,2,0,1,0,0],
[0,1,0,3,0,3,0,1,0],
[1,0,4,0,6,0,4,0,1]]
Como sempre, a solução com o menor número de bytes vence.
print("def pascal(n):\n #make the nested list\n a=[[0 for i in range(2*n+1)] for j in range(n+1)] #make the list\n a[0][n]=1 #add the initial 1\n for i in range(1,n+1):\n for j in range(2*n+1):\n a[i][j]=a[i-1][j-1]+a[i-1][(j+1)%(2*n+1)] #the main part\n return a")