Вопрос задан 09.07.2023 в 22:53. Предмет Информатика. Спрашивает Лимонов Дмитрий.

В заданной строке найти самое длинное слово - Мал золотник да дорог! В Python у строкового типа

данных есть метод split(), который разделяет слова по пробелу (или другому символу, если он передан в качестве аргумента). Получается список слов. Далее из этого списка можно извлекать отдельные слова, обращаясь к ним по индексам. Для решения задачи разбейте строку на слова, возьмите за самое длинное слово - самое первое, а дальше с помощью цикла “for...in range” сравнивайте слова с первым.
0 0
Перейти к ответам

Ответы на вопрос

Внимание! Ответы на вопросы дают живые люди. Они могут содержать ошибочную информацию, заблуждения, а также ответы могут быть сгенерированы нейросетями. Будьте внимательны. Если вы уверены, что ответ неверный, нажмите кнопку "Пожаловаться" под ответом.
Отвечает Kurus Valeria.

Ответ:

Python 3.7

import re

import string

def clrStr(strng: str) -> str:

   return re.sub(r' +', ' ', re.sub(rf'[{string.punctuation}]|\n', '', strng))

raw_string = input()

clean_string = clrStr(raw_string)

print(max(clean_string.split(' '), key = lambda p: len(p)))

И никаких велосипедов с перебором всего списка слов в цикле.

Объяснение:

Да, я специально решил эту задачу не так, как просят в условии. Ведь в условии вам максимально разжевали подход к решению. Но, стоит заметить, что по дурацки. Питоньи списки можно перебирать циклом вида for item in list, не обращаясь к исходному списку по индексам. Так же функция max() может принимать аргумент key, который является функцией, с помощью которой интерпретатор будет выбирать максимум из указанного списка.

0 0
Отвечает нейросеть ChatGpt. Будьте внимательны, ответы нейросети могут содержать ошибочные или выдуманные данные.

Вот пример кода на Python, который решает задачу поиска самого длинного слова в заданной строке:

python
string = "Мал золотник да дорог!" words = string.split() # Разбиваем строку на слова longest_word = words[0] # Первое слово считаем самым длинным for word in words: if len(word) > len(longest_word): longest_word = word print("Самое длинное слово:", longest_word)

В этом коде мы сначала разбиваем исходную строку на слова с помощью метода split(). Затем инициализируем переменную longest_word первым словом из списка итерации words.

Затем мы используем цикл for для итерации по каждому слову в списке words. Внутри цикла проверяем длину текущего слова с длиной самого длинного слова. Если текущее слово длиннее, то обновляем значение переменной longest_word на текущее слово.

После завершения цикла выводим на экран найденное самое длинное слово.

В результате выполнения этого кода будет выведено "Самое длинное слово: золотник".

0 0

Похожие вопросы

Топ вопросов за вчера в категории Информатика

Последние заданные вопросы в категории Информатика

Задать вопрос