Вложенные списковые включения

При работе с двумерными списками также можно перебирать объекты с помощью списковых включений.
grid = [
    [10, 20, 30],
    [40, 50, 60],
]
squared = [[i * i for i in row] for row in grid]
print(squared)
# [[100, 400, 900], [1600, 2500, 3600]]
Здесь внешний цикл проходит по grid построчно. Затем мы перебираем каждый элемент в строке.
Если мы не хотим получить двумерный список в результате, мы можем уплотнить grid, опустив внутренние скобки и переместив for i in row из внутреннего цикла. Сначала мы перебираем grid с помощью for row in grid, а затем for i in row:
grid = [
    [10, 20, 30],
    [40, 50, 60],
]
squared = [i * i for row in grid for i in row]
print(squared)
# [100, 400, 900, 1600, 2500, 3600]

Задание

Можете ли вы с помощью спискового включения вывести все координаты шахматной доски? Номера идут от 1 до 8, а буквы — A B C D E F G H. Нумерация выглядит как A1 B1 C1 ... H1, следующая строка — A2 B2 C2 ... H2 и так далее. Выведите каждую строку отдельно.
Output
A1 B1 C1 D1 E1 F1 G1 H1
A2 B2 C2 D2 E2 F2 G2 H2
A3 B3 C3 D3 E3 F3 G3 H3
A4 B4 C4 D4 E4 F4 G4 H4
A5 B5 C5 D5 E5 F5 G5 H5
A6 B6 C6 D6 E6 F6 G6 H6
A7 B7 C7 D7 E7 F7 G7 H7
A8 B8 C8 D8 E8 F8 G8 H8
Подсказка
Вы можете использовать однострочное условие, чтобы определить, нужно ли вам печатать перевод строки, используя параметр end метода print
 

Constraints

Time limit: 2 seconds

Memory limit: 512 MB

Output limit: 1 MB

To check your solution you need to sign in
Sign in to continue