summaryrefslogtreecommitdiff
path: root/Common/List.lean
diff options
context:
space:
mode:
Diffstat (limited to 'Common/List.lean')
-rw-r--r--Common/List.lean24
1 files changed, 24 insertions, 0 deletions
diff --git a/Common/List.lean b/Common/List.lean
new file mode 100644
index 0000000..4076c87
--- /dev/null
+++ b/Common/List.lean
@@ -0,0 +1,24 @@
+theorem listFilterSmallerOrEqualList (l : List α) (p : α → Bool) : l.length ≥ (l.filter p).length := by
+ induction l with
+ | nil => simp[List.filter]
+ | cons a as hi =>
+ simp[List.length, List.filter]
+ cases (p a) with
+ | false =>
+ simp
+ constructor
+ assumption
+ | true => simp_arith[hi]
+
+
+def quicksort {α : Type} [Ord α] : List α → List α
+| [] => []
+| a :: as =>
+ let smallerPred := λ b ↦ Ord.compare b a == Ordering.lt
+ let largerEqualPred := λ b ↦ Ord.compare b a != Ordering.lt
+ have : List.length (List.filter smallerPred as) < Nat.succ (List.length as) := by simp_arith[listFilterSmallerOrEqualList]
+ have : List.length (List.filter largerEqualPred as) < Nat.succ (List.length as) := by simp_arith[listFilterSmallerOrEqualList]
+ let smallers := as.filter smallerPred
+ let biggers := as.filter largerEqualPred
+ (quicksort smallers) ++ [a] ++ (quicksort biggers)
+ termination_by quicksort l => l.length