Форум программистов, компьютерный форум, киберфорум
Haskell
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/8: Рейтинг темы: голосов - 8, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 05.05.2017
Сообщений: 15

Оставить в списке элементы, которые имеют парное количество вхождений в список

07.05.2017, 16:34. Показов 1767. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Например есть список [1,2,2,3,3,3,4,4,4,4]. Результат: [2,2,4,4,4,4]
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.05.2017, 16:34
Ответы с готовыми решениями:

Оставить в списке элементы, которые имеют парное количество вхождений в список
Например есть список . Результат:

Найти все элементы, которые имеют наибольшее число вхождений в список
Если таких элементов несколько, то вывести их все.

Найти все элементы, которые имеют наибольшее число вхождений в список
2) Найти все элементы, которые имеют наибольшее число вхождений в список.

3
Модератор
 Аватар для Curry
5158 / 3487 / 536
Регистрация: 01.06.2013
Сообщений: 7,567
Записей в блоге: 9
07.05.2017, 17:11
Лучший ответ Сообщение было отмечено Hornel как решение

Решение

Haskell
1
2
3
4
5
6
task :: Eq a => [a] -> [a]
task l = let s = map fst $ filter (even.snd) $
                    foldr (\x t -> case lookup x t of
                           Just i -> (x,i+1):filter ((x/=).fst) t
                           _ -> (x,1::Int):t) [] l
         in filter (`elem` s) l
3
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38193 / 21126 / 4309
Регистрация: 12.02.2012
Сообщений: 34,732
Записей в блоге: 14
07.05.2017, 19:37
Haskell
1
2
3
4
5
6
task :: (Eq a) => [a] -> [a]
task []     = []
task (x:xs) | (even count) = take count (repeat x) ++ go xss
               | otherwise    = go xss 
                 where xss = filter (/= x) xs
                          count = length xs - length xss + 1
2
 Аватар для Araneo
650 / 260 / 16
Регистрация: 02.03.2014
Сообщений: 587
07.05.2017, 20:47
Порядок в котором нужно оставить элементы не оговорен поэтому моё решение выглядит так.
Haskell
1
2
import Data.List
task = concat . filter (even . length) . group . sort
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.05.2017, 20:47
Помогаю со студенческими работами здесь

Оставить в первом списке элементы, которые входят во второй список только один раз
Есть 2 списка. Оставить в первом только те элементы, которые есть во втором только в одном экземпляре.

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

Оставить в первом списке только те элементы которые входят во второй трижды
Пожалуйста, помогите решить задачу на прологе. Дано 2 списка нужно оставить в первом списке только те элементы которые входят во второй...

подсчитать количество знаков препинания; б) вывести все слова что имеют парное количество букв; менять местами
подсчитать количество знаков препинания; б) вывести все слова что имеют парное количество букв; менять местами первую и последнюю букву в...

Определить количество строк которые не имеют нулевые элементы
Задача - определить количество строк которые не имеют нулевые элементы. Проблема - не могу остановить цикл #include...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Программный отбор элементов справочника Номенклатура по группе 1С
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор под наименованию группы (на. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор элементов справочника Сотрудники по перечислениям 1С
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru