I first encountered the
Boyer-Moore string search algorithm in mid-1990s when it was mentioned in a local computer magazine discussing virus detection mechanisms and referred to Cormen's
Introduction to Algorithms for more details.
Back then, DOS was king and Microsoft was omnipotent, with computer viruses as nuances in one's computing experience, the holy grail of computer programming enthusiasts in my
former university (but my college alma mater is
here) was anti-virus programming.
The paradox is that to learn how to create an anti-virus you have to create a virus against which it should work.
Mark Ludwig's bookdata:image/s3,"s3://crabby-images/63a95/63a958cdbd68022b6c92dc1ee78e040afeba9c78" alt=""
data:image/s3,"s3://crabby-images/63a95/63a958cdbd68022b6c92dc1ee78e040afeba9c78" alt=""
was a coveted possession but the only one I got my hands on was
Ralf Burger's work and I learned how to make a functional computer virus then
data:image/s3,"s3://crabby-images/4d0a1/4d0a11acad67ba1a4f48e2167205ef93e2eb5e93" alt=""
. To fix the problem, you have to find it (fast!); this is where virus detection becomes critical, and Boyer-Moore string search algorithm is one of the best algorithms known then for this purpose.