progs/catastrophic.py
author Christian Urban <urbanc@in.tum.de>
Tue, 16 Oct 2018 00:42:10 +0100
changeset 578 6e5e3adc9eb1
parent 558 447ed6c7cdad
child 613 bfd511b7ecbf
permissions -rwxr-xr-x
updated
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
49
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
#!/usr/bin/env python
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
import re
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
import sys
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
558
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
     5
# A case of catastrophic backtracking in Python
420
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
     6
#
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
     7
# regex: (a?){n} a{n}
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
     8
# strings: aa...
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
     9
#
558
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    10
# call with:
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    11
#
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    12
#   > ./catastrophic.py 20
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    13
#
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    14
# or
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    15
#
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    16
#   > ./catastrophic.py 28
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    17
#
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    18
#
420
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
    19
# call with timing as:
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
    20
#
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
    21
#   > time ./catastrophic.py 20
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
    22
558
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    23
447ed6c7cdad updated
Christian Urban <urbanc@in.tum.de>
parents: 420
diff changeset
    24
420
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
    25
# counter n given on the command line
49
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    26
cn = sys.argv[1]
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    27
420
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
    28
# constructing the regex
49
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    29
r1 = '((a?){%s})' % cn
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    30
r2 = 'a{%s}' % cn
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    31
420
25bc57b32efa updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 411
diff changeset
    32
# calling the matching function
49
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    33
m = re.match(r1 + r2 , "a" * int(cn)) 
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    34
d2c6852ca8da added programs and slides
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    35
print m.group(0)