File: reverse.c

package info (click to toggle)
why 2.13-2
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 12,608 kB
  • ctags: 16,817
  • sloc: ml: 102,672; java: 7,173; ansic: 4,439; makefile: 1,409; sh: 585
file content (56 lines) | stat: -rw-r--r-- 947 bytes parent folder | download | duplicates (4)
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56


/* in-place list reversal */

#include "list.h"

/*@ requires is_list(p0)
  @ ensures \forall plist l0; \old(llist(p0, l0)) => llist(\result, rev(l0))
  @*/
list rev(list p0) {
  list r = p0;
  list p = NULL;
  /*@ invariant 
        \exists plist lp; \exists plist lr;
          llist(p, lp) && llist(r, lr) && disjoint(lp, lr) &&
          \forall plist l; 
            \old(llist(p0, l)) => app(rev(lr), lp) == rev(l)
    @ variant length(r) for length_order */
  while (r != NULL) {
    list q = r;
    r = r->tl;
    q->tl = p;
    p = q;
  }
  return p;
}

/* test */

#if 0
#include <stdio.h>

void print(list l) {
  if (l == NULL) 
    printf("NULL\n");
  else {
    printf("%d :: ", l->hd);
    print(l->tl);
  }
}

int main() {
  /* 1::2::3::NULL */
  struct struct_list l[3];
  list r;
  l[0].hd = 1;
  l[0].tl = &l[1];
  l[1].hd = 2;
  l[1].tl = &l[2];
  l[2].hd = 3;
  l[2].tl = NULL;
  print(l);
  r = rev(l);
  print(r);
}
#endif