Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22

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

19.03.2016, 03:34. Показов 2158. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: показать затраченные материалы за определенный период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В качестве. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru