220 likes | 409 Views
String Processing. Basic Terminology. Each programming language contains a character set that is used to communicate with the computer. It includes the following: Alphabet : A B C D….Z, a b c…….z Digits : 0 1 2 3….9 Special characters : + - / * ( )……
E N D
Basic Terminology • Each programming language contains a character set that is used to communicate with the computer. It includes the following: • Alphabet: A B C D….Z, a b c…….z • Digits: 0 1 2 3….9 • Special characters: + - / * ( )…… • A finite sequence S of zero or more characters is called a string.
Basic Terminology • The number of characters in a string is called its length. • The string with zero characters is called the empty string or the null string. • Specific strings will be denoted by enclosing their characters in single quotation marks. • For example, ‘THE END’, ‘TO BE OR NOT TO BE’
Basic Terminology • Blank space is a character and hence contributes to the length of the string. • Let S1 and S2 be strings. The string consisting of the characters of S1 followed by the characters of S2 is called the concatenation of S1 and S2; it is denoted by S1 // S2. for example, • ‘THE’ // ‘END’ = ‘THEEND’ • The length of S1 // S2 is equal to the sum of the lengths of the strings S1 and S2.
Basic Terminology • A string Y is called a substring of a string S if there exist strings X and Z such that • S = X // Y // Z • If X is an empty string, then Y is called an initial substring of S, and if Z is an empty string then Y is called a terminal substring of S. for example, • ‘BE OR NOT’ is a substring of ‘TO BE OR NOT TO BE’
String Operations • ‘THE’ is an initial substring of ‘THE END’ • Clearly, if Y is a substring of S, then the length of Y can’t exceed the length of S. • Substring: • Accessing a substring from a given string requires three pieces of information (1) the name of the string, (2)the position of the first character of the substring in the given string and (3) the length of the substring or the position of the last character of the substring.
String Operations • SUBSTRING (string, initial, length): it denotes the substring of a string S beginning in a position K and having a length L. for example, • SUBSTRING (‘TO BE OR NOT TO BE’, 4, 7) = ‘BE OR N’ • SUBSTRING (‘THE END’, 4, 4) = ‘ END’
String Operations • Indexing: also called pattern matching, refers to finding the position where a string pattern P first appears in a given string text T. we call this operation INDEX and write • INDEX (text, pattern) • If the pattern P does not appear in the text T, then index is assigned the value 0. The arguments “text” and “pattern” can be either string constants or string variables.
String Operations • Suppose T contains the text “HIS FATHER IS THE PROFESSOR” then • INDEX (T, ‘THE’), INDEX (T, ‘THEN’) and INDEX(T, ‘ THE ’)have the values 7, 0 and 14 respectively.
String Operations • Concatenation: • Let S1 and S2 be strings. The concatenation of S1 and S2, which is usually denoted by S1 // S2, is the string consisting of the characters of S1 followed by the characters of S2. • Suppose S1 = ‘MARK’ and S2 = ‘TWAIN’ • Then S1 // S2 = ‘MARKTWAIN’
String Operations • Length: • The number of characters in a string is called its length. We will write • LENGTH(string) for the length of a given string. Thus • LENGTH(‘COMPUTER’) = 8 • LENGTH(‘’) = 0
String Operations Insertion: Suppose in a given text T, we want to insert a string S so that S begins in position K: we denote this operation by INSERT(text, position, string) For example, INSERT(‘ABCDEFG’, 3, ‘XYZ’) = ‘ABXYZCDEFG’
String Operations • This INSERT function can be implemented by using the string operations defined previously as follows: • INSERT(T, K, S) = SUBSTRING(T, 1, K-1) // S // SUBSTRING(T, K, LENGTH(T) – K + 1 )
String Operations • The initial substring of T before the position K, which has length K - 1, is concatenated with the string S, and the result is concatenated with the remaining part of T, which begins in position K and has length LENGTH(T) – (K-1) = LENGTH(T) - K + 1
String Operations • Deletion: • Suppose in a given text T, we want to delete the substring which begins in position K and has length L. we denoted this operation by • DELETE(text, position, length) • For example, • DELETE(‘ABCDEFG’, 4, 2) = ‘ABCFG’
String Operations • DELETE(‘ABCDEFG’, 0, 2) = ‘ABCDEFG’ • This function can also be implemented in terms of other functions: • DELETE(T, K, L) = SUBSTRING(T, 1, K-1) // SUBSTRING(T, K + L, LENGTH(T) – K – L + 1) • The initial substring of T before position K is concatenated with the terminal substring of T beginning in position K + L.
Algorithm 3.1 • A text T and a pattern P are in memory. This algorithm deletes every occurrence of P in T. • 1. [Find index of P] Set K := INDEX(T, P) • 2. Repeat while K ≠ 0 • (a) [Delete P from T] • Set T := DELETE(T, K, LENGTH(P) ) • (b) [Update index] Set K := INDEX (T, P) • [End of loop] • 3. Write: T. • 4. Exit
Algorithm 3.2 • A text T and patterns P and Q are in memory. This algorithm replaces every occurrence of P in T by Q. • 1. [Find index of P] Set K:= INDEX (T, P) • 2. Repeat while K ≠ 0: • (a) [Replace P by Q] Set T := REPLACE (T, P, Q) • (b) [Update index] Set K := INDEX (T, P) • [End of loop] • 3. Write: T. • 4. Exit.
Algorithm 3.3 • (Pattern Matching) P and T are strings with lengths R and S respectively. This algorithm finds the INDEX of P in T.
Pattern Matching • 1. [Initialize] Set K := 1 and MAX := S – R + 1 • 2. Repeat steps 3 to 5 while K ≤ MAX • 3. Repeat for L = 1 to R: [Tests each character of P.] • If P[L] ≠ T[K + L - 1], then: Go to step 5 • [End of inner loop] • 4. [Success] Set INDEX = K, and exit • 5. Set K := K + 1 • [End of step 2 outer loop] • 6. [Failure] Set INDEX = 0 • 7. Exit.