source: CIVL/examples/loop_invariants/selectSort.cvl@ b0ff124

1.23 2.0 main test-branch
Last change on this file since b0ff124 was e93c797, checked in by Ziqing Luo <ziqing@…>, 8 years ago

change PARSE_ACSL to CVL_ACSL

git-svn-id: svn://vsl.cis.udel.edu/civl/trunk@4569 fb995dde-84ed-4084-dfe6-e5aef3e2452c

  • Property mode set to 100644
File size: 927 bytes
Line 
1#include <assert.h>
2#pragma CIVL ACSL
3$input int N;
4$assume(N > 0);
5int a[N];
6
7int main() {
8 int i, j;
9
10 $havoc(&a);
11 /*@ loop invariant 0 <= i && i <= N;
12 @ loop invariant \forall int t; N-i+1<=t && t <N ==>
13 @ a[t] <= a[t-1];
14 @ loop invariant \forall int t; 0 <= t && t < N-i && i > 0 ==>
15 @ a[t] >= a[N-i];
16 @ loop assigns i, j, a[0 .. N-1];
17 @*/
18 for (i = 0; i < N; i++) {
19 int minIdx = 0;
20 /*@ loop invariant 0<=j && j <=N-i && 0<=minIdx &&
21 @ minIdx<N-i;
22 @ loop invariant \forall int t; 0<=t && t <j ==>
23 @ a[t] >= a[minIdx];
24 @ loop assigns j, minIdx;
25 @*/
26 for (j = 0; j < N-i; j++)
27 if (a[j] < a[minIdx])
28 minIdx = j;
29
30 int tmp = a[minIdx];
31
32 a[minIdx] = a[N-i-1];
33 a[N-i-1] = tmp;
34 }
35 assert($forall (int i : 1 .. N-1) a[i] <= a[i-1]);
36 return 0;
37}
Note: See TracBrowser for help on using the repository browser.