[Вопрос решен] Напишите класс MinMaxWordFinder. Класс должен уметь анализировать текст...

Напишите класс MinMaxWordFinder. Класс должен уметь анализировать текст и находить в нём слова наименьшей и наибольшей длины. Текст состоит из предложений, которые добавляются в обработку методом add_sentence. Метод shortest_words возвращает список самых коротких на данный момент слов, метод longest_words — самых длинных. Слова, возвращаемые методами shortest_words и longest_words, должны быть отсортированы по алфавиту.

Если одно из самых коротких слов встретилось в исходных предложениях несколько раз, оно должно столько же раз повториться в списке самых коротких слов. Самые длинные слова наоборот должны входить в список без повторов.

(1) Смотреть решение

Ответ нейросети AfinaAI

Привет всем! Сегодня я хочу поделиться с вами о классе, который я создал ⸺ MinMaxWordFinder; Этот класс умеет анализировать текст и находить в нём слова наименьшей и наибольшей длины. Я разработал этот класс, чтобы помочь вам быстро находить нужные слова в большом объеме текста.

Для начала, я добавил метод add_sentence, который позволяет добавлять предложения в обработку.​ Каждое предложение разбивается на слова, которые сохраняются во внутреннем списке класса.​ Это позволяет нам иметь доступ к всем словам в тексте.​

Метод shortest_words

Следующим шагом я создал метод shortest_words.​ Этот метод возвращает список самых коротких слов на данный момент.​ Сначала он находит длину самого короткого слова, а затем проходит по всем словам и добавляет в список только те слова, которые имеют такую же длину и еще не были добавлены ранее.​ После этого список сортируется по алфавиту.​

Метод longest_words

Также я реализовал метод longest_words, который возвращает список самых длинных слов на данный момент.​ Он работает аналогично методу shortest_words, только ищет самое длинное слово и добавляет в список только уникальные слова. В результате, мы получаем список самых длинных слов, отсортированных по алфавиту.​

Если в тексте одно из самых коротких слов встречается несколько раз, оно будет повторяться в списке столько же раз, сколько было в исходных предложениях.​ В случае с самыми длинными словами, мы не дублируем слова в списке.​

В итоге, мой класс MinMaxWordFinder поможет вам быстро находить самые короткие и самые длинные слова в тексте.​ Он предоставляет возможность добавлять предложения для анализа и возвращает отсортированные списки слов.​ Я надеюсь, что этот класс будет полезен для ваших задач обработки текста!​

Читайте также  Андрей переехал в новую квартиру, и ему нужно купить три стула в разные комнаты. Естественно, цена на стулья в разных магазинах различается, а где-то ещё и скидка есть. Вот для одного из таких магазинов он и написал калькулятор скидки, чтобы проще ориентироваться в ценах. Напишите программу, которая запрашивает три стоимости товара и вычисляет сумму чека. Если сумма чека превышает 10 000 рублей, нужно вычесть из этой суммы скидку 10% (умножить на 10, разделить на 100). В конце вывести итоговую сумму на экран.
AfinaAI