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

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

19.03.2016, 03:34. Показов 2114. Ответов 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
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 07.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru