8 / 7 / 1
Регистрация: 09.06.2017
Сообщений: 34

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

15.04.2019, 20:07. Показов 37472. Ответов 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
5234 / 3479 / 1175
Регистрация: 21.03.2016
Сообщений: 8,306
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
BOINC: 22 года — и всё ещё работает
Programma_Boinc 12.03.2026
BOINC: 22 года — и всё ещё работает Дэвид Андерсон написал ретроспективу. Кратко: в 2001 году он ушёл из United Devices, где был CTO, и за несколько месяцев написал ядро BOINC — клиент, сервер,. . .
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru