Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

In this exercise we deal with the problem of string matching.

  1. Explain how to use a brute-force algorithm to find the first occurrence of a given of m characters, called the target, in a string of n characters, wheremn, called the text. [Hint: Think in terms of finding a match for the first character of the target and checking successive characters for a match, and if they do not all match, moving the start location one character to the right].
  2. Express your algorithm in pseudocode.
  3. Give a big-O estimate for the worst-case time complexity of the brute-force algorithm you described.

Short Answer

Expert verified
  1. If match is found, algorithm should stop and return to the location of the occurrence of string.
  2. else i := i + 1

return location.

3. O(n log n)

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

(a)Step 1: Brute-force algorithm

We have two strings: one string a1a2...anwith n characters and one string data-custom-editor="chemistry" b1,b2...bm with m characters with .

We want to determine if the string occurs within the string mn.

We will first check if the first element b1is in the string role="math" localid="1668668563903" b1b2...bm (thus need to check it for a1toan-m+1, because if is one of the other elements, then the entire string role="math" localid="1668668556255" b1b2...bmcannot be within a1a2...an).

If the element is found, then the algorithm needs to check if the next character in a1a2...anis b1. If it is, then we need to check if the next character b3and so on.

If they do not match, then we need to move the start location to the next character.

If a match is found, the algorithm should stop and return the location of the occurrence of the string b1b2...bmin a1a2...an.

Note: If the algorithm returns the empty set ϕ, then this will mean that the string b1b2...bmdoes not occur in a1a2...an.

02

(b) Step 2: Write algorithm

We call the algorithm “string matching” and the input is two strings: one stringwith n characters and one stringb1b2...bmwith m characters withmn.

Procedure: string matching(a1a2...an:stringwithn1,b1b2...bmstringwith1mn).

The variable “location” will keep track if a location of the string is found. The value ϕindicates that no match is found. The variable i will keep track of position in the string a1a2...anwhere we are currently checking for b1.

location :=ϕ

i := 1

If a match is found, the algorithm should stop and return the location of the occurrence of the stringb1b2...bmina1a2...an.

We will first check if the first elementb1b2...bmis in the stringdata-custom-editor="chemistry" a1a2...an.

If the elementb1is found, then the algorithm needs to check if the next character ina1a2...anisb2. If it is, then we need to check if the next character isb3and so on.

If they do not match, then we need to move the start location to the next character.

The variable j will keep track of the location in the stringb1b2...bm. If no match is found, we set the value of j tom+2such that the while-loop will stop and such that j reaching the value m + 1 means that every character in the string b1b2...bmwas matched.

whilein-m+1andlocation=ϕ

ifb1=aithen

j:=2

whilejmandlocation=ϕ

ifrole="math" localid="1668669455924" bjai+j-1then

i:=i+jj:=m+2

else j:=j+1

ifj=m+1thenlocation:=i,i+1,i+2,...i+m-1

else role="math" localid="1668669561235" i:=i+1

03

(c)Step 3: Write algorithm

Finally, the algorithm should return the variable “location” which keep track of the location ofb1b2...bmin the stringa1a2...an.

return location.

Combining all these steps, we then obtain the algorithm:

Procedure- string matching(a1a2...an:stringwithn1,b1b2...bmstringwith1mn)

location:=ϕi:=1

whilein-m+1andlocation=ϕ

ifb1=aithen

j:=2

whilejmandlocation=ϕ

ifbjai+j-1then

i:=i+jj:=m+2

else j:=j+1

if j=m+1thenlocation:=i,i+1,i+2,...,i+m-1

else i:=i+1

return location.

04

(d) Step 4: Worst case scenario

If the entire string a1a2...andoes not contains b1, then the outer while-loop is executed n - m + 1 times and the inner while-loop is never executed. The outer while-loop makes 3 comparisons per iteration comparisons made.

Worst-case scenario- If the string role="math" localid="1668670033252" a1a2...anis made up out of the substrings b1b2...bm-1then the inner while-loop is executed times before ending and the inner while-loop is executed logm-1ntimes before ending. The outer while-loop made comparisons, while the inner while-loop made 3 comparisons.

In total, the algorithm, then makes data-custom-editor="chemistry" 4(m-2)(4+3)logm-1n=28(n-2)logm-1ncomparisons and 23(m-2)logm-1nisO(nlogn)(sincemn).

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free