Еще циклы можно использовать, чтобы формировать строки. Подобная задача часто встречается в веб-программировании. Она сводится к обычной агрегации, когда применяется интерполяция или конкатенация.
Переворот строки — алгоритмическая задача, которую задают на собеседованиях. Правильный способ перевернуть строку — использовать функцию из стандартной библиотеки. Но важно знать, как ее реализовать.
Один из алгоритмов выглядит так:
Строим новую строку
Перебираем символы исходной строки в обратном порядке
def reverse_string(string):
index = len(string) - 1
reversed_string = ''
while index >= 0:
current_char = string[index]
reversed_string = reversed_string + current_char
# То же самое через интерполяцию
# reversed_string = f'{reversed_string}{current_char}'
index = index - 1
return reversed_string
reverse_string('Game Of Thrones') # 'senorhT fO emaG'
# Проверка нейтрального элемента
reverse_string('') # ''
Разберем функцию построчно:
index = len(string) - 1
— записываем в новую переменную индекс последнего символа строки (индексы начинаются с нуля)reversed_string = ''
— инициализируем строку, куда будем записывать результатwhile index >= 0:
— условие: повторяем тело цикла, пока текущий индекс не дошел до 0
— до первого символаcurrent_char = string[index]
— берем из строки символ по текущему индексуreversed_string = reversed_string + current_char
— записываем в строку-результат новое значение: текущая строка-результат + новый символindex = index - 1
— обновляем счетчикreturn reversed_string
— когда цикл завершился, возвращаем строку-результатСоветуем скопировать эту функцию в https://replit.com/languages/python3 и поэкспериментировать с ней.
Работая со строками, программисты часто допускают ошибку — выходят за границы строки. Если неправильно подобрать начальное значение счетчика или допустить ошибку в предикате цикла, функция может обращаться к несуществующему символу.
Особенно часто забывают, что индекс последнего элемента всегда меньше на единицу размера строки. В строках начальный индекс равен 0
, значит, индекс последнего элемента — len(str) - 1
.
Реализуйте функцию my_substr()
, которая извлекает из переданной строки подстроку указанной длины. Она принимает на вход два аргумента: строку и длину, и возвращает подстроку, начиная с первого символа:
Пример вызова:
string = 'If I look back I am lost'
print(my_substr(string, 1)) # => 'I'
print(my_substr(string, 7)) # => 'If I lo'
Используйте тот же подход, что в функции для переворота строки из урока: собирайте строку-результат в цикле, перебирая начальную строку до определённого момента.
Эту задачу можно решить при помощи слайсов. Но в этом упражнении мы хотим потренироваться в использовании циклов и поэтому реализуем эту функциональность самостоятельно. Именно так внутри и работают слайсы.
Если вы зашли в тупик, то самое время задать вопрос в «Обсуждениях». Как правильно задать вопрос:
Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.
Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи.
В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.
Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в «Обсуждениях». Идеально, если вы сформулируете непонятные моменты в виде вопросов. Обычно нам нужно несколько дней для внесения правок.
Кстати, вы тоже можете участвовать в улучшении курсов: внизу есть ссылка на исходный код уроков, который можно править прямо из браузера.
Ваше упражнение проверяется по этим тестам
1import index
2
3
4def test1():
5 assert index.my_substr('got', 3) == 'got'
6 assert index.my_substr('got', 2) == 'go'
7 assert index.my_substr('got', 1) == 'g'
8
Решение учителя откроется через: