[Перевод] Python: 18 задач на вывод символов по заданному шаблону 11.04.2021 20:19
Подготовка к техническому собеседованию по Python — нелёгкая задача. На таком собеседовании вам, вполне возможно, встретятся задачи на вывод символов по заданным шаблонам. Если вы хотите научиться решать такие задачи — вам может пригодиться подборка способов их решения, приведённая в этом материале.

Здесь продемонстрировано 18 примеров кода. Начинающие программисты вполне могут проработать всё по порядку, а опытные могут разобраться именно с тем, что им нужно. Главное — понять, как устроен тот или иной пример. Отсутствие чёткого понимания того, что происходит в программах, способно сыграть злую шутку с тем, кто, например, заучив фрагмент кода и воспроизведя его на собеседовании, попытается объяснить то, как именно этот код работает. А тех, кто проводит собеседование, часто интересуют именно такие вот разъяснения.
1. Простой числовой треугольник
Желаемый результат:
1 2 2 3 3 3 4 4 4 4 5 5 5 5 5
rows = 6 for num in range(rows): for i in range(num): print(num, end=" ") # вывод числа # вывод пустой строки после каждой строки с числами для правильного отображения шаблона print(" ")
2. Обратный числовой треугольник
Желаемый результат:
1 1 1 1 1 2 2 2 2 3 3 3 4 4 5
rows = 5 b = 0 for i in range(rows, 0, -1): b += 1 for j in range(1, i + 1): print(b, end=' ') print('\r')
3. Полупирамида из чисел
Желаемый результат:
1 1 2 1 2 3 1 2 3 4 1 2 3 4 5
rows = 5 for row in range(1, rows+1): for column in range(1, row + 1): print(column, end=' ') print("")
4. Обратная пирамида из уменьшающихся чисел
Желаемый результат:
5 5 5 5 5 4 4 4 4 3 3 3 2 2 1
rows = 5 for i in range(rows, 0, -1): num = i for j in range(0, i): print(num, end=' ') print("\r")
5. Обратная пирамида, все элементы которой представлены одним и тем же числом
Желаемый результат:
5 5 5 5 5 5 5 5 5 5 5 5 5 5 5
rows = 5 num = rows for i in range(rows, 0, -1): for j in range(0, i): print(num, end=' ') print('\r')
6. Пирамида из чисел, расположенных в обратном порядке
Желаемый результат:
1 2 1 3 2 1 4 3 2 1 5 4 3 2 1
rows = 6 for row in range(1, rows): for column in range(row, 0, -1): print(column, end=' ') print("")
7. Обратная полупирамида из чисел
Желаемый результат:
0 1 2 3 4 5 0 1 2 3 4 0 1 2 3 0 1 2 0 1
rows = 5 for i in range(rows, 0, -1): for j in range(0, i + 1): print(j, end=' ') print('\r')
8. Пирамида из натуральных чисел меньше 10
Желаемый результат:
1 2 3 4 5 6 7 8 9
currentNumber = 1 stop = 2 rows = 3 # Количество строк, из которых состоит пирамида for i in range(rows): for column in range(1, stop): print(currentNumber, end=' ') currentNumber += 1 print("") stop += 2
9. Пирамида из чисел от 10, расположенных в обратном порядке
Желаемый результат:
1 3 2 6 5 4 10 9 8 7
start = 1 stop = 2 currentNumber = stop for row in range(2, 6): for col in range(start, stop): currentNumber -= 1 print(currentNumber, end=' ') print("") start = stop stop += row currentNumber = stop
10. Пирамида из определённых наборов цифр
Желаемый результат:
1 1 2 1 1 2 3 2 1 1 2 3 4 3 2 1 1 2 3 4 5 4 3 2 1
rows = 6 for i in range(1, rows + 1): for j in range(1, i - 1): print(j, end=" ") for j in range(i - 1, 0, -1): print(j, end=" ") print()
11. Обратная пирамида из связанных чисел
Желаемый результат:
5 4 3 2 1 1 2 3 4 5 5 4 3 2 2 3 4 5 5 4 3 3 4 5 5 4 4 5 5 5
rows = 6 for i in range(0, rows): for j in range(rows - 1, i, -1): print(j, '', end='') for l in range(i): print('', end='') for k in range(i + 1, rows): print(k, '', end='') print('\n')
12. Пирамида из чётных чисел
Желаемый результат:
10 10 8 10 8 6 10 8 6 4 10 8 6 4 2
rows = 5 LastEvenNumber = 2 * rows evenNumber = LastEvenNumber for i in range(1, rows+1): evenNumber = LastEvenNumber for j in range(i): print(evenNumber, end=' ') evenNumber -= 2 print("\r")
13. Пирамида из наборов чисел
Желаемый результат:
0 0 1 0 2 4 0 3 6 9 0 4 8 12 16 0 5 10 15 20 25 0 6 12 18 24 30 36
rows = 7 for i in range(0, rows): for j in range(0, i + 1): print(i * j, end=' ') print()
14. Пирамида, в каждой строке которой выводятся разные числа
Желаемый результат:
1 3 3 5 5 5 7 7 7 7 9 9 9 9 9
rows = 5 i = 1 while i
15. Зеркально отражённая пирамида из чисел (прямоугольный числовой треугольник)
Желаемый результат:
1 1 2 1 2 3 1 2 3 4 1 2 3 4 5
rows = 6 for row in range(1, rows): num = 1 for j in range(rows, 0, -1): if j > row: print(" ", end=' ') else: print(num, end=' ') num += 1 print("")
16. Равносторонний треугольник из символов *
Желаемый результат:
size = 7 m = (2 * size) - 2 for i in range(0, size): for j in range(0, m): print(end=" ") m = m - 1 # уменьшение m после каждого прохода цикла for j in range(0, i + 1): # вывод пирамиды из звёздочек print("*", end=' ') print(" ")
17. Перевёрнутый треугольник из символов *
Желаемый результат:
rows = 5 k = 2 * rows - 2 for i in range(rows, -1, -1): for j in range(k, 0, -1): print(end=" ") k = k + 1 for j in range(0, i + 1): print("*", end=" ") print("")
18. Пирамида из символов *
Желаемый результат:
rows = 5 for i in range(0, rows): for j in range(0, i + 1): print("*", end=' ') print("\r")
Какие задачи вы посоветовали бы прорешать тем, кто готовится к собеседованию по Python?
Задача. Колонтитул (Python)
Нам нужно написать программу для печати важных объявлений. Сверху объявления должен располагаться вот такой колонтитул:
![]()
Восклицательные знаки всегда располагаются по центру строки, причём в зависимости от важности объявления количество восклицательных знаков может быть разным. Напишите программу, которая спрашивает у пользователя сначала общую длину колонтитула в символах, потом желаемое количество восклицательных знаков, после чего выводит на экран готовую строку.
Решение задачи:
row = 1 sign = int(input('Введите кол-во знаков в колонтитуле: ')) exc = int(input('Введите кол-во восклицательных знаков: ')) for i in range(row): rows = '~' * sign rows = rows + '!' * exc + rows print() print(rows)
Из символов * cделать пирамиду

Помогите написать программу (не полностью, а подсказать), которая выводит из символов * делают пирамиду формат ввода: Одно целое число - высота пирамиды (для картинки это число 3 ).
Формат вывода: Пирамида в формате, аналогичном показанному в примере. Я ещё очень зелёный в этой теме, поэтому пока туплю. Написал вот это(бред, но я пытался)
x=int(input()) for i in range(x): print('*'*x)
Используется python 3.6
Отслеживать
48.6k 17 17 золотых знаков 56 56 серебряных знаков 100 100 бронзовых знаков
задан 18 окт 2017 в 20:44
vojdelenije vojdelenije
147 2 2 золотых знака 2 2 серебряных знака 13 13 бронзовых знаков
Осталось слева пробелы добавлять
18 окт 2017 в 20:53
Я пошел вообще другим путем - выравнивание символов по левому краю\центру\правому краю. т.е. есть некая переменная, которая равна желаемой ширине пирамидки. Ну ок, строим пирамидку, и выравниваем по какому нужно параметру. Если нужно решение - сброшу, но подсказка более чем очевидна.
3 апр 2018 в 19:52
7 ответов 7
Сортировка: Сброс на вариант по умолчанию
x=int(input()) for i in range(x): print('%s%s' % (' ' * (x-i-1), '*' * (i*2+1)))
Отслеживать
ответ дан 18 окт 2017 в 21:22
user239133 user239133
а что значит '%s%s' ?
18 окт 2017 в 21:33
– user239133
18 окт 2017 в 21:37
огромное спасибо)))
18 окт 2017 в 21:39
можно чуть проще: for i in range(n): print(' ' * (n-i-1) + '*' * (i*2+1))
19 окт 2017 в 20:38
@jfs, можно плюс на запятую заменить еще. По идее, так результат будет отправляться в stdout без лишнего конката (у меня в ответе соответственно лишнее форматирование). Но тут странные ответы и вопрос со словом "зеленый", что можно трактовать двояко, поэтому править ответ и поднимать вопрос на главную не нужно, наверное.
– user239133
19 окт 2017 в 20:47
Я читаю вашу картинку слева направо, но только по отвесную ось симметрии:
* - 2 пробелы, 1 звездочка ** - 1 пробел, 2 звездочки *** - 0 пробелов, 3 звездочки
Пробелов убывает, звездочек прибывает, но сумма пробелов и звездочек всегда 3
(в общем случае это x ).
Пусть количество звездочек будет в переменной i .
И так как i меняется от 1 по x (здесь x равно 3 ), вы можете писать:
* - (x - 1) пробелов, 1 звездочка (i == 1 в этой итерации)
** - (x - 2) пробелов, 2 звездочки (i == 2 в этой итерации)
*** - (x - 3) пробелов, 3 звездочки (i == 3 в этой итерации)
Значит, мы будем пользоваться циклом
for i in range(1, x + 1):
причем число звездочек будет i и число пробелов (x - i) .
Да, я пока читал вашу картину только по отвесную ось, но прибавить остальные звездочки не будет проблема — или будет? (Всегда о 1 менее чем до отвесной оси.)
for i in range(1, x + 1): spaces = (x - i) * ' ' asterisks = i * '*' + (i - 1) * '*' print(f'')
f (в Python 3.6+) непосредственно перед
- начальным апострофом, или
- начальной кавычкой
строки обозначает f-строку (форматированную).
ПОМОГИТЕ, ПОЖАЛУЙСТА, С ПИТОН.
Задача 8. Колонтитул
Нам нужно написать программу для печати важных объявлений. Сверху объявления должен располагаться вот такой колонтитул:
Восклицательные знаки всегда располагаются по центру строки, причём в зависимости от важности объявления количество восклицательных знаков может быть разным. Напишите программу, которая спрашивает у пользователя сначала общую длину колонтитула в символах, потом желаемое количество восклицательных знаков, после чего выводит на экран готовую строку.
Задание 8. Получить нужно два числа.
1 - длина полоски
2 - количество восклицательных знаков
Сделать расчеты, чтобы символы "~" при итоговом выводе были одинаковы с двух сторон.
Например:
Длина полоски: 13
Количество восклицательных знаков: 7
~~~ . ~~~
Голосование за лучший ответ
А почему у тебя в примере длина полоски получилась 9, а количество восклицательных знаков - 3?
Абра КадабраУченик (33) 2 года назад
это пример нам скинули такую
Абра КадабраУченик (33) 2 года назад
сможете помочь?
Улугбек Мастер (1181) Абра Кадабра, нет, я не вижу логики. В примере задают длину строки 13, количество воскл. знаков - 7, а в результате получаем длину 9 и кол-во воскл знаков 3. Где логика?
Абра КадабраУченик (33) 2 года назад
а можете тогда скинуть набросок этой задачи без этого примера, пожалуйста
Улугбек Мастер (1181) Абра Кадабра, тут все зависит от того, что будет в приоритете. Если в приоритете количество восклицательных знаков и чтобы в конечной строке было хотя бы по одной тильде на краях, то может и такой код подойдет: l, s = map(int, input().split()) if l >= s + 2: str = '~'*((l-s)//2) str += '!'*s + str print(str) else: print('Не хватает длины строки')
n,nn = int(input('Длина полоски: ')),int(input('Количество восклицательных знаков: '))
print('~' * ((n - nn) // 2), '!' * nn, '~' * ((n - nn) // 2))
Абра КадабраУченик (33) 2 года назад
спасибо вам огромное
Абра КадабраУченик (33) 2 года назад

Только не надо вводить длину полоски и колво восклицательных знаков. Нам нужно написать предложение и после этого провести эти расчёты.
Улугбек Мастер (1181) Абра Кадабра, а от чего зависит количество воскл знаков?
Абра КадабраУченик (33) 2 года назад
где 5 там 2, где 13 там 5, т. е. на 2,5 слова один восклицательный знак
length = int(input('Введите длину колонтитула в символах: '))
mark = int(input('Введите количество восклицательных знаков: '))
tilde = (length - mark) // 2
if (length - mark) // 2 == 0:
print('~' * tilde + '!' * mark + '~' * tilde)
else:
print('~' * tilde + '!' * mark + '~' * (tilde+1))
print('Задача 8. Колонтитул')
# Нам нужно написать программу для печати важных объявлений.
# Сверху объявления должен располагаться вот такой колонтитул:
# ~~~~~~~~~~. ~~~~~~~~~~
# Восклицательные знаки всегда располагаются по центру строки,
# причём в зависимости от важности объявления количество восклицательных знаков может быть разным.
#
# Напишите программу,
# которая спрашивает у пользователя сначала общую длину колонтитула в символах,
# потом желаемое количество восклицательных знаков,
# после чего выводит на экран готовую строку.
leng = int(input('Введите длину колонтитула в символах: '))
sign = int(input('Введите желаемое количество восклицательных знаков: '))
tilde = (leng - sign) // 2
if (leng - sign) // 2 == 0:
print('~' * tilde + '!' * sign + '~' * tilde)
else:
print('~' * tilde + '!' * sign + '~' * (tilde + 1))