Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22

Не понимаю такой алгоритм (поиск самого длинного слова в файле)

19.03.2016, 03:34. Показов 2142. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Python
1
2
3
f = "sex rock dragndrop a get pock laaaaaaaaaaaa gas"
s = max(map(lambda x: (len(x), x), f.split(" ")))
print (s[1])
Мне друг сказал что этот код поможет. Как его понимать (код в смысле)?
Код непонятный.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.03.2016, 03:34
Ответы с готовыми решениями:

Поиск самого длинного слова в файле
Дан символьный файл f. Найти самое длинное слово среди слов, вторая буква которых есть е; если слов с наибольшей длинной несколько, то...

Поиск самого длинного слова в файле
вот задание Задание к лабораторной работе № 7. Ввод данных осуществляется из файла с pасшиpением .DAT. Использовать ТОЛЬКО...

Поиск самого длинного слова в файле
Создать файл file.txt с помощью текстового редактора, длина которого не превышает 70 символов. Написать программу, которая: 1) выводит...

4
 Аватар для YakobsEA
268 / 96 / 75
Регистрация: 04.12.2015
Сообщений: 369
Записей в блоге: 1
19.03.2016, 05:41
f.split(" ") - возвращает список строк, полученных из исходной строки путём её разбиения на подстроки, используя в качестве разделителя пробел
map - производит указанную операцию над каждым элементом списка. В Вашем случае преобразует каждый элемент в кортеж. В кортеже нулевой элемент - длина подстроки, первый - сама подстрока
max - выбирает элемент c максимальным нулевым элементом в кортеже из результата, возвращаемого map
s[1] - возвращает первый элемент выбранного кортежа, т.е. максимальное слово.

Наверняка Вы смогли бы и сами разобраться, проанализировав, что возвращает каждая часть кода. Примерно вот так:

Python
1
2
3
4
5
6
f = "sex rock dragndrop a get pock laaaaaaaaaaaa gas"
print(f.split(" "))
print(*map(lambda x: (len(x), x), f.split(" ")))
s = max(map(lambda x: (len(x), x), f.split(" ")))
print (s)
print (s[1])
Вот результат, если у Вас питона нет под рукой:

['sex', 'rock', 'dragndrop', 'a', 'get', 'pock', 'laaaaaaaaaaaa', 'gas']
(3, 'sex') (4, 'rock') (9, 'dragndrop') (1, 'a') (3, 'get') (4, 'pock') (13, 'laaaaaaaaaaaa') (3, 'gas')
(13, 'laaaaaaaaaaaa')
laaaaaaaaaaaa

Ну и погуглите "python map" для окончательного понимания.
1
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
19.03.2016, 07:37  [ТС]
Хорошо
0
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
19.03.2016, 11:16
Всё от нежелания читать документацию: навернули кучу ненужных действий. Функция max умеет сама находить по функции
Python
1
2
f = "sex rock dragndrop a get pock laaaaaaaaaaaa gas"
print(max(f.split(), key=len))
0
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
19.03.2016, 14:08  [ТС]
Навернул мой друг, а не я. Я всего лишь пытался понять код
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.03.2016, 14:08
Помогаю со студенческими работами здесь

Разработать программу, осуществляющую поиск самого короткого и самого длинного слова во вводимом тексте
Разработать программу, осуществляющую поиск самого короткого и самого длинного слова во вводимом тексте. С комментами)

Поиск самого короткого и самого длинного слова массива
Возникла проблема, программа наименьшим считает всегда первое слово #include <iostream> #include <conio.h> #include...

Удаление самого длинного слова в файле
Всем доброго времени суток, помогите пожалуйста доделать задачу: Вот условие: Напишите программу, которая считывает текст из файла и...

Нахождение самого длинного слова в текстовом файле
написать программу нахождения самого длинного слова в текстовом файле и выводов всех слов наибольшей длины. Словом считать набор символов...

Поиск самого длинного слова
Задание дали создать файл с текстом , среди этого текста найти самое длинное слово, и показать сколько раз оно повторилось в тексте , код...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
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
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru