Форум программистов, компьютерный форум, киберфорум
Haskell
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
0 / 0 / 0
Регистрация: 20.12.2013
Сообщений: 14
1

Реализовать drop используя fold

17.08.2015, 13:03. Показов 3273. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Как можно реализовать библиотечные функции drop и dropWhile ,используя fold?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.08.2015, 13:03
Ответы с готовыми решениями:

Drag and drop - как реализовать?
Доброго времени суток, попался мне один лэндинг в качестве учебного, там есть в конце оказался...

Реализовать Drag & Drop на форму
Как сделать что-бы окно программы распознавало перетаскиваемые файлы

Не могу реализовать условие Drag and Drop
Здравствуйте форумчане! private class ChoiceDragListener implements OnDragListener {...

Встраивание элемента в элемент используя Drag and Drop
Нужно осуществить что-то вроде паззла, только в другом направлении. У меня на форме два Shape и два...

6
4817 / 2278 / 287
Регистрация: 01.03.2013
Сообщений: 5,947
Записей в блоге: 28
17.08.2015, 14:01 2
Хааароший вопрос Ядреная Теория оригами-стайл кодинга утверждает, что через фолд-анфолд можно сделать все что только можно себе вообразить (хотя это и трудно себе представить). В данном же конкретном случае можно относительно просто навелосипедить простой вариант с (++), а по-хорошему можно посмотреть как это реализуют умные люди, знакомые с Ядреной Теорией (С) - https://www.cs.nott.ac.uk/~gmh/fold.pdf
0
Модератор
5047 / 3276 / 526
Регистрация: 01.06.2013
Сообщений: 6,806
Записей в блоге: 9
17.08.2015, 14:40 3
Не оптимальные велосипеды с (++) .
Haskell
1
2
3
4
5
6
7
8
9
10
11
12
import Prelude hiding (drop,dropWhile)
 
drop :: Int -> [a] -> [a]
drop i = fst . foldl (\ (r,b) a -> if b>0 then (r,b-1) else (r++[a],0)) ([],i)
                                        
dropWhile :: (a -> Bool) -> [a] -> [a]
dropWhile p = fst . foldl (\ (r,b) a -> let b' = b && p a in 
                                        (if b' then r else r++[a],b')) ([],True)
 
main = do
    print $ drop 6 "Hello World!"
    print $ dropWhile (< 3) [1,2,3,4,5,1,2,3]

Не по теме:

_Ivana, исключил Вас из списка игнорирования. До первого кода на лиспе тут.



Добавлено через 26 минут
А вот, без (++)
Haskell
1
2
3
4
5
6
7
8
9
10
11
12
import Prelude hiding (drop,dropWhile)
 
drop :: Int -> [a] -> [a]
drop i l = fst $ foldr (\ a (r,b) -> if b>0 then (a:r,b-1) else (r,0)) ([],length l - i) l
                                        
dropWhile :: (a -> Bool) -> [a] -> [a]
dropWhile p l = drop (fst $ foldl (\ (i,b) a -> let b' = b && p a in
                                                (if b' then i+1 else i,b')) (0,True) l) l
 
main = do
    print $ drop 6 "Hello World!"
    print $ dropWhile (< 3) [1,2,3,4,5,1,2,3]
1
Модератор
Эксперт функциональных языков программированияЭксперт Python
36601 / 20330 / 4220
Регистрация: 12.02.2012
Сообщений: 33,643
Записей в блоге: 13
17.08.2015, 14:42 4
Не очень ловко... Например, так:

Haskell
1
2
3
4
5
6
7
8
drop' :: Int -> [a] -> [a]
drop' n x = foldl (\ acc p -> if (p > n) then acc else tail acc) x [1..(length x)]
 
dropWhile' :: (a -> Bool) -> [a] -> [a]
dropWhile' p x = snd $ foldl f (True,[]) x
                 where f acc z = if (fst acc) then
                                    if (p z) then (True, []) else (False, (snd acc) ++ [z])
                                 else (False, (snd acc) ++ [z])
1
Модератор
5047 / 3276 / 526
Регистрация: 01.06.2013
Сообщений: 6,806
Записей в блоге: 9
17.08.2015, 16:21 5
Между прочим. Часто не хватает свёрток или map-ов с возможностью досрочного выхода, типа
Haskell
1
foldl'' :: (b -> a -> (b,Bool)) -> b -> t a -> b
Делается, конечно, элементарно, но в базовых библиотеках нет.
1
Эксперт функциональных языков программированияЭксперт Java
4486 / 2721 / 485
Регистрация: 28.04.2012
Сообщений: 8,590
17.08.2015, 16:31 6
Цитата Сообщение от Catstail Посмотреть сообщение
Не очень ловко... Например, так:
Тогда уж, может быть, как-то так:

Haskell
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import Prelude hiding (drop, dropWhile)
 
drop n xs = foldl tailor xs [1..n]
 
dropWhile f xs = foldl tailor xs $ truths f xs
 
tailor [] _ = []
tailor xs _ = tail xs
 
truths f [] = []
truths f (x:xs) = if f x then True : truths f xs else []
 
main = do
    let xs   = [1..10]
    let pd n = print $ drop n xs
    let pw f = print $ dropWhile f xs
    pd (-1)
    pd   0
    pd   1
    pd  20
    pw (<  0)
    pw (<  5)
    pw (< 15)
=>
Bash
1
2
3
4
5
6
7
[1,2,3,4,5,6,7,8,9,10]
[1,2,3,4,5,6,7,8,9,10]
[2,3,4,5,6,7,8,9,10]
[]
[1,2,3,4,5,6,7,8,9,10]
[5,6,7,8,9,10]
[]
1
Модератор
Эксперт функциональных языков программированияЭксперт Python
36601 / 20330 / 4220
Регистрация: 12.02.2012
Сообщений: 33,643
Записей в блоге: 13
17.08.2015, 16:37 7
Цитата Сообщение от KolodeznyDiver Посмотреть сообщение
Делается, конечно, элементарно, но в базовых библиотеках нет.
- да, и мне эта мысль тоже приходила.
0
17.08.2015, 16:37
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.08.2015, 16:37
Помогаю со студенческими работами здесь

MFC Drag and Drop Как его реализовать?
Доброе время суток. Как реализовать Drag and Drop между двумя List Control'ами?

Как реализовать Drag'n'Drop для ListBox?
Опять я. Все отталкивал на потом &quot;как сделать&quot;, да так и не доходят руки и мозги:) Мне нужно...

Как реализовать Drag And Drop из Listbox в RichTextBox
всем приветы. прошу помощи у сведущих форумчан. Имею на форме заполненный Listbox и пустой...

Как реализовать drag-and-drop в Windows Forms?
Как реализовать drag-and-drop в Windows Forms?


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru