source: CIVL/examples/verifyThisProblems/relaxedPrefix.c@ b7a3ce6

1.23 2.0 main test-branch
Last change on this file since b7a3ce6 was 0ae124a, checked in by Yihao Yan <yihaoyan1@…>, 10 years ago

format changes

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

  • Property mode set to 100644
File size: 1.8 KB
Line 
1/*
2author: Yihao
3
4Link(challenge 1): http://etaps2015.verifythis.org/challenges
5
6problem description:
7Verify a function isRelaxedPrefix determining if a list _pat_ (for
8pattern) is a relaxed prefix of another list _a_.
9
10The relaxed prefix property holds iff _pat_ is a prefix of _a_ after
11removing at most one element from _pat_.
12
13examples:
14
15pat = {1,3} is a relaxed prefix of a = {1,3,2,3} (standard prefix)
16
17pat = {1,2,3} is a relaxed prefix of a = {1,3,2,3} (remove 2 from pat)
18
19pat = {1,2,4} is not a relaxed prefix of a = {1,3,2,3}.
20
21command: civl verify RelaxedPrefix_2015_1.c
22
23*/
24
25#include <stdio.h>
26#include <stdbool.h>
27#include <civlc.cvh>
28
29$input int N1_BOUND = 4;
30$input int N2_BOUND = 3;
31$input int n1;
32$input int n2;
33$input int X2[n2];
34$input int X1[n1];
35$assume (n2>=0 && n2 < N2_BOUND);
36$assume (n1>=0 && n1 < N1_BOUND);
37
38bool isRelaxedPrefix(int* pat, int patLen, int* a, int aLen) {
39 int shift = 0;
40 int i;
41
42 if(patLen > aLen+1) return false;
43
44 if(aLen == 0) return true;
45
46 for(i=0; i<patLen; i++) {
47 if(pat[i] != a[i-shift]) {
48 if(shift == 0)
49 shift = 1;
50 else
51 return false;
52 }
53 if(i == aLen - 1 && shift == 0) return true;
54 }
55 return true;
56}
57
58void main() {
59 bool result = isRelaxedPrefix(X1, n1, X2, n2);
60
61 if(n1 > n2+1) {
62 $assert(!result);
63 } else if(n1 == n2+1) {
64 $assert( result ==
65 ($exists {int k | k >= 0 && k < n1}
66 (
67 ($forall {int i | i >= 0 && i < k} X1[i] == X2[i]) &&
68 ($forall {int i | i > k && i < n1} X1[i] == X2[i-1])
69 )
70 )
71 );
72 } else {
73 $assert(result ==
74 ($exists {int k | k >= 0 && k <=n1}
75 (
76 ($forall {int i | i >= 0 && i < k} X1[i] == X2[i]) &&
77 ($forall {int i | i > k && i < n1} X1[i] == X2[i-1])
78 )
79 )
80 );
81 }
82}
Note: See TracBrowser for help on using the repository browser.