80 likes | 164 Views
Synthesis with the Sketch System. Day 3. Armando Solar- Lezama. In place list reversal. Problem statement. Given a list like this: Produce a list like this :. head. head. Constraints . Your algorithm must be O(n) Your algorithm must use a constant space
E N D
Synthesis with the Sketch System Day 3 Armando Solar-Lezama
Problem statement • Given a list like this: • Produce a list like this: head . . . head . . .
Constraints • Your algorithm must be O(n) • Your algorithm must use a constant space • It can not use arrays or recursion
The Spec harness voidmain(int n){ if(n >= MAXN){ n = MAXN-1; } node[n] nodes = null; list l = newList(); popList(n, l, nodes); reverseSK(l); check(n, l, nodes); }
The Spec voidpopList(int n, list l, refnode[n] nodes){ node tail= null; for(int i=0; i<n;++i){ node t = newNode(); if(i>0){ tail.next = t; }else{ l.head = t; } tail = t; nodes[i] = t; } }
The Spec void check(int n, list l, node[n] nodes){ node cur = l.head; inti=0; while(cur != null){ assertcur == nodes[n-1-i]; cur = cur.next; i = i+1; } asserti == n; if(n > 0){ assertl.head == nodes[n-1]; }else{ assertl.head == null; } }
The Sketch voidreverseSK(ref list l){ node tmp1 = null;node tmp2 = null; while( ){ } } {| (tmp1 | tmp2 | l.head)(.next)? |}