相关疑难解决方法(0)

从Haskell中的列表中删除重复项

我正在尝试定义一个将从列表中删除重复项的函数.到目前为止,我有一个有效的实现:

rmdups :: Eq a => [a] -> [a]
rmdups [] = []
rmdups (x:xs)   | x `elem` xs   = rmdups xs
                | otherwise     = x : rmdups xs
Run Code Online (Sandbox Code Playgroud)

但是我想在不使用的情况下重做这件事elem.什么是最好的方法?

我想用我自己的功能而不是nub或者这样做nubBy.

recursion haskell list

26
推荐指数
4
解决办法
5万
查看次数

将列表拆分为可能的元组列表

我需要将列表拆分为所有可能元组的列表,但我不确定如何这样做.

例如:

pairs ["cat","dog","mouse"]
Run Code Online (Sandbox Code Playgroud)

应该导致:

[("cat","dog"), ("cat","mouse"), ("dog","cat"), ("dog","mouse"), ("mouse","cat"), ("mouse","dog")]

我能够形成前两个,但我不确定如何得到其余的.

这是我到目前为止所拥有的:

pairs :: [a] -> [(a,a)]
pairs (x:xs) = [(m,n) | m <- [x], n <- xs]
Run Code Online (Sandbox Code Playgroud)

haskell tuples list-comprehension

24
推荐指数
3
解决办法
4896
查看次数

标签 统计

haskell ×2

list ×1

list-comprehension ×1

recursion ×1

tuples ×1