Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.90/179: Рейтинг темы: голосов - 179, средняя оценка - 4.90
8 / 7 / 1
Регистрация: 09.06.2017
Сообщений: 34

В тексте найти самые короткие и самые длинные слова

15.04.2019, 20:07. Показов 37433. Ответов 4
Метки нет (Все метки)

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


Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
class MinMaxWordFinder:
    def __init__(self):
        self.text = []
 
 
    def add_sentence(self, add):
        for i in add.split():
            self.text.append((len(i), i))
 
 
    def shortest_words(self):
        return sorted([j[1] for j in self.text if j[0] == sorted([i[0] for i in self.text])[0]])
 
 
    def longest_words(self):
        return sorted([j[1] for j in self.text if j[0] == sorted([i[0] for i in self.text])[-1]])

Ввод:
finder = MinMaxWordFinder()
finder.add_sentence('hello')
finder.add_sentence('abc')
finder.add_sentence('world')
finder.add_sentence('abc')
finder.add_sentence('def')
finder.add_sentence('asdf')
finder.add_sentence('abc')
finder.add_sentence('qwert')
finder.add_sentence('world')
print(' '.join(finder.shortest_words()))
print(' '.join(finder.longest_words()))


Ожидаемый результат
abc abc abc def
hello qwert world



Вывод
abc abc abc def
hello qwert world world



Как это исправить
3
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.04.2019, 20:07
Ответы с готовыми решениями:

Самые короткие и самые длинные слова
Напишите класс MinMaxWordFinder. Класс должен уметь анализировать текст и находить в нём слова наименьшей и наибольшей длины. Текст состоит...

Самые короткие и самые длинные слова
Написать класс MinMaxWordFinder. Класс должен уметь анализировать текст и находить в нём слова наименьшей и наибольшей длины. Текст состоит...

Ввести два предложения и распечатать самые длинные слова, общие для этих предложений
Ввести два предложения и распечатать самые длинные слова общие для этих предложений. Если нужных слов нет - сообщить об этом

4
 Аватар для Semen-Semenich
5230 / 3476 / 1174
Регистрация: 21.03.2016
Сообщений: 8,304
16.04.2019, 09:43
Лучший ответ Сообщение было отмечено vladddddddddddd как решение

Решение

Python
1
2
def longest_words(self):
    return sorted(set([j[1] for j in self.text if j[0] == sorted([i[0] for i in self.text])[-1]]))
2
 Аватар для m0nte-cr1st0
1043 / 578 / 242
Регистрация: 15.01.2019
Сообщений: 2,178
Записей в блоге: 1
16.04.2019, 11:31
Можно и через map решить
Python
1
return sorted(set([i[1] for i in self.text if i[0] == max(map(lambda x: x[0], self.text))]))
Только на большом тексте эти "однострочные" решения не выгодны будут. Вот, как вариант.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
class MinMaxWordFinder:
    def __init__(self):
        self.text = []
 
    def add_sentence(self, add):
        for i in add.split():
            self.text.append((len(i), i))
 
    def shortest_words(self):
        l = []
        min_ = self.text[0][0]
        for i in self.text:
          if i[0] < min_:
            l = [i[1]]
            min_ = i[0]
          elif i[0] == min_:
            l.append(i[1])
        return sorted(l)
 
    def longest_words(self):
        l = []
        max_ = self.text[0][0]
        for i in self.text:
          if i[0] > max_:
            l = [i[1]]
            max_ = i[0]
          if i[0] == max_ and i[1] not in l:
            l.append(i[1])
        return sorted(l)
3
 Аватар для Lok1zer0
0 / 0 / 0
Регистрация: 10.05.2020
Сообщений: 5
12.05.2020, 14:51
Выводит ошибку, при использовании вашего кода.
Миниатюры
В тексте найти самые короткие и самые длинные слова   В тексте найти самые короткие и самые длинные слова  
0
1 / 1 / 0
Регистрация: 17.03.2024
Сообщений: 2
17.03.2024, 10:26
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
class MinMaxWordFinder:
    def __init__(self):
        self.text = []
 
    def add_sentence(self, add):
        for i in add.split():
            self.text.append(i)
 
    def shortest_words(self):
        lst = []
        for i in filter(lambda x: len(x) <= len(min(self.text, key=lambda x: len(x))), self.text):
            lst += [i]
        return sorted(lst)
 
    def longest_words(self):
        lst = set()
        for i in filter(lambda x: len(x) >= len(max(self.text, key=lambda x: len(x))), self.text):
            lst.add(i)
        return sorted(lst)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.03.2024, 10:26
Помогаю со студенческими работами здесь

В заданом тексте найти самые короткие и самые длинные слова.
В заданом тексте найти самые короткие и самые длинные слова. Если можно, то с блок-схемкой

Поменять местами самые короткие и самые длинные слова в тексте
В файле есть текст. Определены самое короткое и самое длинное слова. Нужно поменять их местами в тексте.

В текстовом файле найти самые длинные и самые короткие слова и удалить их из файла.
Людти добрые помогите пожалуйсто кателок уже совсоем не варит задача :в текстовом файле найти самые длинные и самые короткие слова и...

Из исходной строки исключить самые длинные и самые короткие слова
Из исходной строки исключить самые длинные и самые короткие слова. Вот такое вот задание. Нельзя использовать функции и процедуры....

В данном предложение найти самые короткие и длинные слова
№1 Программирование алгоритмов обработки последовательности символов: В данном предложение найти самые короткие и длинные слова.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru