exception - SML - 在快速排序算法中找不到“未捕获异常空”的位置
问题描述
我正在尝试在不使用任何 List.nth 函数的情况下编写快速排序算法。我想出了这个,但是当我尝试测试它时,它最终抛出了一个“未捕获的异常空”。我似乎无法找到引发此异常的位置。这是我的代码:
(*returns last element in list*)
fun last (h::nil) = h
| last(h::lst) = last(lst)
| last _ = ~1;
(*returns middle element in list*)
fun middle (lst) =
let
fun middle_rec (_ :: []) (x :: _) = x
| middle_rec (_ :: _ :: []) (x :: _) = x
| middle_rec (_ :: _ :: xs) (_ :: ys) = middle_rec xs ys
| middle_rec _ _ = ~1
in
middle_rec lst lst
end;
(*return median of three elements*)
fun median(a,b,c) =
if ((b>a andalso a>c) orelse (c>a andalso a>b))
then a
else if ((a>b andalso b>c) orelse (c>b andalso b>a))
then b
else if ((a>c andalso c>b) orelse (b>c andalso c>a))
then c
else ~1;
(*partitions a list with one containing elements smaller than or equal to p and one with elements greater than p*)
fun partition([], p) = ([],[])
| partition(lst,p) =
let
fun part_rec ([], x::xs, y::ys, p) = (x::xs, y::ys)
| part_rec (lst, x, y, p) =
if hd(lst) <= p
then part_rec(tl(lst), hd(lst)::x, y, p)
else part_rec(tl(lst), x, hd(lst)::y, p)
in
part_rec(lst,[],[],p)
end;
(*quicksort function*)
fun quicksort [] = []
| quicksort(x::xs) =
let val (left, right) = partition(x::xs, median(x, middle(x::xs), last(x::xs)))
in
quicksort left @ [x] @ quicksort right
end;
quicksort([9,4,7,2,8,5,1,6,4,3]);
解决方案
推荐阅读
- xml - ROS Remap 主题不起作用 - 多个机器人
- python-3.x - 没有这样的选项:尝试从 Git 安装 discord.py 时在 Heroku 上使用 -U
- vue.js - 有没有办法使用firebase实时数据库(vuejs)进行分页?
- jquery - 为什么 jQuery 中需要 each() 方法?$('.mycls1').css(etc) 不是更自然吗?
- windows - 如何在 Windows 上的 powershell 上执行 sudo
- azure - AllMetrics for Log Analytics for Azure Functions 2.x 下包含哪些字段
- shell - 如何从cantos tmp文件夹中删除php会话文件
- python - Postgis ST_GeomFromWKB 返回遇到无效的字节序标志值
- postgresql - postgresql – Debian 伸展上没有 crypt 功能
- sql - 为什么布尔字段在 Hive 中不起作用?