-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathInsertionSort.dfy
38 lines (34 loc) · 1001 Bytes
/
InsertionSort.dfy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
predicate sorted (a:array<int>, start:int, end:int) // all "before" end are sorted
requires a!=null
requires 0<=start<=end<=a.Length
reads a
{
forall j,k:: start<=j<k<end ==> a[j]<=a[k]
}
method InsertionSort (a:array<int>)
requires a!=null && a.Length>1
ensures sorted(a, 0, a.Length)
modifies a
{
var up := 1;
while (up < a.Length) // outer loop
invariant 1 <= up <= a.Length
invariant sorted(a,0,up)
{
var down := up-1;
var temp := a[up];
while down >= 0 && a[down+1] < a[down] // inner loop
invariant forall j,k | 0 <= j < k < up+1 && k != down+1 :: a[j]<=a[k]
{
a[down],a[down+1] := a[down+1],a[down];
down := down-1;
}
up := up+1;
}
}
method Main(){
var a := new int[5];
a[0],a[1],a[2],a[3],a[4] := 3,2,5,1,8;
InsertionSort(a);
print a[..];
}