| author | Christian Urban <christian.urban@kcl.ac.uk> | 
| Thu, 30 Jul 2020 13:50:54 +0100 | |
| changeset 742 | b5b5583a3a08 | 
| parent 741 | e66bd5c563eb | 
| child 753 | d94fdbef1a4f | 
| permissions | -rw-r--r-- | 
| 558 | 1 | # A case of catastrophic backtracking in Ruby | 
| 2 | #--------------------------------------------- | |
| 563 | 3 | # example provided by Daniel Baldwin | 
| 558 | 4 | # | 
| 563 | 5 | # | 
| 558 | 6 | # regex: (a?){n} a{n}
 | 
| 7 | # strings: aa... | |
| 8 | # | |
| 563 | 9 | # run on the command line with: | 
| 558 | 10 | # | 
| 742 | 11 | # ruby catastrophic.rb | 
| 558 | 12 | # | 
| 58 | 13 | |
| 226 
e3c454e31224
updated so that it works with more recent versions of Ruby
 Christian Urban <christian dot urban at kcl dot ac dot uk> parents: 
121diff
changeset | 14 | nums = (1..1000) | 
| 57 | 15 | |
| 474 | 16 | #iterate through the nums 1-1000 | 
| 57 | 17 | nums.each do |i| | 
| 18 | ||
| 19 | start_time = Time.now | |
| 20 | string = "a" * i | |
| 474 | 21 | |
| 22 | #create a new regular expression based on current value of i | |
| 226 
e3c454e31224
updated so that it works with more recent versions of Ruby
 Christian Urban <christian dot urban at kcl dot ac dot uk> parents: 
121diff
changeset | 23 | re_str = "a?" * i + "+" + "a" * i | 
| 
e3c454e31224
updated so that it works with more recent versions of Ruby
 Christian Urban <christian dot urban at kcl dot ac dot uk> parents: 
121diff
changeset | 24 | re = Regexp.new(re_str) | 
| 57 | 25 | |
| 60 | 26 | re.match(string) | 
| 474 | 27 | |
| 28 | #if re.match(string) | |
| 60 | 29 | 	#	puts "matched string  a * #{i} with regex #{re}"
 | 
| 30 | #else | |
| 31 | 	#	puts "unmatched string a * #{i} with regex #{re}"
 | |
| 32 | #end | |
| 57 | 33 | |
| 60 | 34 |   puts "#{i} %.5f" % (Time.now - start_time)
 | 
| 57 | 35 | end |