我有以下函数,它接受一个列表并返回在给定元素 n 处拆分的两个子列表。但是,我只需要将它分成两半,奇数长度的列表具有更大的第一个子列表
splitlist :: [a] -> Int -> ([a],[a])
splitlist [] = ([],[])
splitlist l@(x : xs) n | n > 0 = (x : ys, zs)
| otherwise = (l, [])
where (ys,zs) = splitlist xs (n - 1)
我知道我需要将签名更改为 [a] -> ([a],[a]),但是我应该在代码中的哪个位置放置诸如 length(xs) 这样的内容,以免中断递归?