lab5问题集合
斐波那契数列
- 他有两个base case,就是a1 = 1,然后a2的时候也是1。
rangeSum
- 调用函数的时候a+1和b-1要分别括号括起来
- 首先你那个rangesum只要输入两个值啊,你调用的时候只输了一个值。
- 然后就是当X等于Y的话,你确定是加零而不是加X吗?
- 因为rangesum的话,假设你X是起始值,Y是终点值,X等于Y的时候,就是它们两个相等了吗?那你就加随便一个也无所谓,然后你如果不两个不相等的话,就是说你可以把X,然后加上调用这function (X+1) y或者是你把最大值减少也可以,就是y + 调用函数X (Y-1)。就是一样的,你可以自己拿个例子试一下。
rangeList
- 思路有问题,你是比如说我有一有个十,然后你就相当于说本来应该要输出,按顺序是一二三四五六七八九十,但是你输出的最后两个是1 10倒数,倒数第二是2 9就不是符合他要的顺序。
- 然后range list就是报错的第一个截图,里面range list什么什么东西,冒号一个list就冒号的话,只是把单个元素加进list,如果你要加两个list的话,你要用++
- 你就不需要两个两个输出,你可以一个一个输吗?就比如说你只改上限,就调用的时候只改上限或者只改下限都可以啊,就比如说我如果先把a放到前面去,然后冒号调用function,然后(a+1) b。
Ex8: firstList, lastList
- 这么写输出是对的, 但最好用recursion
因为下面张图误导了好几个同学, 给大家写一下lastList该怎么写
-- guarded
lastList [] = error "随便什么报错都行"
lastList (x:xs)
| length (x:xs) == 1 = x
| otherwise = lastList xs
或者
-- 枚举
lastList [] = error "随便什么报错都行"
lastList [x] = x
lastList (x:xs) = lastList xs
或者
-- caseExpression
lastList [] = error "随便什么报错都行"
lastList (x:xs) = case (length (x:xs)) > 1 of
True -> lastList xs
False -> x
- 你如果你要返回list的最后一个值,你直接调用last就可以了, 但最好用recursion
Ex9: prepend, append
- 这么写输出是对的, 但最好用recursion
swapFirstTwo, swapLastTwo
- 就我没有看你的那个错误提示啊,我看你那个函数交换最后两个那个他X:XS:Y,意思就是X是第一个元素,XS是第二个元素,Y是后面所有东西,然后你又变成X:Y:XS,X:list:XS是不行的。只能把元素放在:左边, 而冒号的最后一个必须是list
- 然后这位同学说: 我能不能把整个顺序倒过来然后换前两个。可行,用reverse 再 swapFirstTwo 再reverse。
- 我觉得你可以用length (z:y:xs) ?然后length他如果等于零的话怎么样?如果等于一的话怎么样?然后如果大于一的话怎么样?