1

嗨,我是 Haskell 初学者,我真的迷路了。这是我的任务,它要求我使用更高的订单功能执行以下操作

Main> mySort (<) [1,5,3,6,4,1,3,3,2] 
[1,1,2,3,3,3,4,5,6] 
Main> mySort (>) [1,5,3,6,4,1,3,3,2] 
[6,5,4,3,3,3,2,1,1] 
Main> mySort longerWord [“Hello”, “The”, “a”, “Daniel”, “Declarative”]
[“Declarative”, “Daniel”, “Hello”, “The”, “a”]

首先,我想我应该做一个函数来区分它是 < , > 还是 longWord

checkConditionStr::String->Int
checkConditionStr str
    |str=="(<)" =1
    |str=="(>)" =2
    |str=="longerWord" =3

但该示例没有引号(即 mysort (<) not my sort"(<)" 所以这是我的第一个问题。我写了这个函数但它没有编译。否则是更长的Word

checkCondition::Ordering->Int
checkCondition ord
    |ord==(<) =1
    |ord==(>) =2
    |otherwise =2

其次,我仍然难以理解高阶函数。这有意义吗?

mySort::(String->Int)->[a]->[a]
mySort i list
    |i==1 map (sortBy compare) list
    |i==2 map (sortBy(flip compare)) list
4

1 回答 1

5

您不应该专门匹配这些功能。它首先破坏了使用高阶函数的目的。事实上,你不能这样写,因为没有比较函数的通用方法。

相反,直接使用传递的函数进行排序。这样,它将适用于任何合适的比较函数,而不仅仅是您明确为其编写代码的那些。

例如,假设任务是使用传递的运算符组合两个值:

combine (+) 2 3 = 5
combine (*) 3 5 = 15
combine max 10 100 = 100

你会这样解决它:

combine op x y = x `op` y

你能用类似的方法来解决排序问题吗?

提示:您可能需要定义一个辅助函数来将传递的比较函数转换为适合的形式sortBy

compareUsing :: (a -> a -> Bool) -> (a -> a -> Ordering)
compareUsing op x y = ...
于 2013-04-19T10:05:48.047 回答