TAREFA
O objetivo é escrever um programa que gire qualquer lista bidimensional em 45 graus; ele deve ser capaz de fazer isso até 7 * 45 (de uma vez) antes de retornar a lista. A lista não será necessariamente quadrada ou retangular. Você deve incluir a saída para os exemplos em sua resposta. Também deve funcionar para casos que não estão nos exemplos ... círculos, triângulos etc. Você não pode usar uma função preexistente para fazer a coisa toda.
Todas as listas terão pelo menos um eixo de simetria (N, S, E, W). Todas as sublistas devem ser assumidas como alinhadas ao centro. As listas ímpares serão deslocadas para a esquerda para alinhar corretamente. Veja o exemplo 4 para lacunas no meio de uma sub-lista.
ENTRADA
Seu programa usará uma variável denominada l
contendo a lista e uma variável denominada n
especificando a quantidade que a lista será rotacionada (n * 45) ( n
sempre será menor que 7 e pode ser 0). Ele precisará aceitar l
sublistas de qualquer tipo de dados imprimíveis (decimal, Lista, int, String [] .. etc), mas as sublistas conterão apenas um tipo de dados por vez.
Você não precisa aceitar a entrada do console ou usar stdin. As linhas que especificam os valores de teste l
e n
não estão incluídas na contagem de caracteres, mas devem ser incluídas no código enviado.
SAÍDA
Seu programa deve imprimir a lista na orientação correta; o NIL pode ser usado para preencher listas, se você desejar, mas o preenchimento não é necessário (você recebe uma carinha sorridente, se forem preenchidas). As sub-listas não precisam ser recuadas ou separadas por novas linhas, como nos exemplos.
EXEMPLOS
1
IN
l=
[[0 , 1 , 2],
[3 , 4 , 5],
[6 , 7 , 8]]
n=1
OUT
[ [0],
[3 , 1],
[6 , 4 , 2],
[7 , 5],
[8] ]
2
IN
l=
[[a , b , c , d],
[e , f , g , h]]
n=2
OUT
[[e , a],
[f , b],
[c , g],
[h , d]]
3
IN
l=
[[A , B , C , D , E , F],
[G , H , I , J],
[K , L],
[0 , 8],
[M , N],
[O , P , Q , R],
[S , T , U , V , W , X]]
n=7
OUT
[ [F],
[E],
[D , J],
[C , I],
[B , H , L],
[A , G , K , 8],
[0 , N , R , X],
[M , Q , W],
[P , V],
[O , U],
[T],
[U] ]
4
IN
l=
[[9 , 8 , 7 , 6],
[5],
[4 , 3 , 2 , 1],
[0] ]
n=3
OUT
[ [0 , 4],
[3],
[2 , 5 , 9],
[1 ,NIL, 8],
[7],
[6], ]
5
IN
l=
[ [Q],
[X ,NIL, Y],
[Z] ]
n=2
OUT
[ [X],
[Z ,NIL, Q],
[Y] ]
n
vezes e não emn
· 45 °? Estou perguntando, porque tenho certeza de que não obteria o resultado do exemplo 3 aplicando sete rotações de 45 °.Respostas:
Python -
234201Versão Ungolfed
Isso usa que a multiplicação (de um número complexo) por um número complexo corresponde a rotação e alongamento.
[1,1+1j,1j,1j-1,-1,-1j-1,-1j,1-1j]
são números complexos que correspondem aos ângulos necessários e usam o menor fator de escala, de modo que, para uma entrada de complexo inteiro, a saída é novamente um complexo inteiro.fonte
else: line += [None]
após o quarto da última linha.