progs/catastrophic/catastrophic.rb
author Christian Urban <christian.urban@kcl.ac.uk>
Fri, 24 Oct 2025 10:45:17 +0100
changeset 1017 b0d44eb1ecc7
parent 753 d94fdbef1a4f
permissions -rwxr-xr-x
updated

#!/usr/bin/env ruby

# A case of catastrophic backtracking in Ruby
#---------------------------------------------
# example provided by Daniel Baldwin
#
# 
# regex: (a?){n} a{n}
# strings: aa...
#
# run on the command line with:
#
# ./catastrophic.rb
#

nums = (1..30)

#iterate through the nums 1-30
nums.each do |i|

	start_time = Time.now
	string = "a" * i

        #create a new regular expression based on current value of i
	re_str = "a?" * i + "+" + "a" * i
	re = Regexp.new(re_str)

        re.match(string)

        #if re.match(string)
	#	puts "matched string  a * #{i} with regex #{re}"
	#else
	#	puts "unmatched string a * #{i} with regex #{re}"
	#end
	
  puts "#{i} %.5f" % (Time.now - start_time)
end