Recognizing strings based on a set of restrictions is a common computational problem. A Slop is a string of characters that has certain properties. Your program will read in strings of characters and output whether or not they are Slops. A Slip is a character string that has the following properties: Its first character is either a 'D' or an 'E' The first character is followed by a string of one or more 'F's The string of one or more 'F's is followed by either a Slip or a 'G' The Slip or 'G' that follows the F's ends the Slip. For example, DFFEFFFG is a Slip since it has a 'D' for its first character, followed by a string of two F's, and ended by the Slip 'EFFFG' Nothing else is a Slip A Slap is a character string that has the following properties: Its first character is an 'A' If it is a two-character Slap then its second and last character is an 'H' If it is not a two-character Slap, then it is in one of these two forms: 'A' followed by 'B' followed by a Slap, followed by a 'C' 'A' followed by a Slip (see above) followed by a 'C' Nothing else is a Slap A Slop is a character string that consists of a Slap followed by a Slip. Examples:  Slips:           DFG, EFG, DFFFFFG, DFDFDFDFG, DFEFFFFFG Not Slips:   DFEFF, EFAHG, DEFG, DG, EFFFFDG Slaps:          AH, ABAHC, ABABAHCC, ADFGC, ADFFFFGC, ABAEFGCC, ADFDFGC Not Slaps:   ABC, ABAH, DFGC, ABABAHC, SLAP, ADGC Slops:       AHDFG, ADFGCDFFFFFG, ABAEFGCCDFEFFFFFG Not Slops:   AHDFGA, DFGAH, ABABCC       Write a program that will read input from a file and determine whether or not a string of characters is a slop. The file will be organized as follows. The first line contains an integer N between 1 and 100 indicating how many strings of characters are to be tested. The next N lines each contain a string. Write three recursive methods that determine whether or not a string is a slop. Here are the function signatures: bool isSlop(string str); bool isSlap(string str); bool isSlip(string str); You will want to write isSlip first, followed by isSlap, and finally isSlop. Make sure that isSlip and isSlap work flawlessly. Do not proceed to isSlop until you are sure that the other two methods work. Your program should write its output to the console.  The first line of output should read SLOPS OUTPUT.  Each of the next N lines of output should consist of either YES or NO depending on whether or not the corresponding input line is a Slop. The last line of output should read: END OF OUTPUT. Shown below is a sample run.  The following input data: 2 AHDFG DFGAH Should produce the following output: SLOPS OUTPUT YES NO END OF OUTPUT

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question
100%

Recognizing strings based on a set of restrictions is a common computational problem. A Slop is a string of characters that has certain properties. Your program will read in strings of characters and output whether or not they are Slops.

A Slip is a character string that has the following properties:

  • Its first character is either a 'D' or an 'E'
  • The first character is followed by a string of one or more 'F's
  • The string of one or more 'F's is followed by either a Slip or a 'G'
  • The Slip or 'G' that follows the F's ends the Slip. For example, DFFEFFFG is a Slip since it has a 'D' for its first character, followed by a string of two F's, and ended by the Slip 'EFFFG'
  • Nothing else is a Slip

A Slap is a character string that has the following properties:

  • Its first character is an 'A'
  • If it is a two-character Slap then its second and last character is an 'H'
  • If it is not a two-character Slap, then it is in one of these two forms:
    • 'A' followed by 'B' followed by a Slap, followed by a 'C'
    • 'A' followed by a Slip (see above) followed by a 'C'
  • Nothing else is a Slap

A Slop is a character string that consists of a Slap followed by a Slip.

Examples: 

Slips:           DFG, EFG, DFFFFFG, DFDFDFDFG, DFEFFFFFG
Not Slips:   DFEFF, EFAHG, DEFG, DG, EFFFFDG

Slaps:          AH, ABAHC, ABABAHCC, ADFGC, ADFFFFGC, ABAEFGCC, ADFDFGC
Not Slaps:   ABC, ABAH, DFGC, ABABAHC, SLAP, ADGC

Slops:       AHDFG, ADFGCDFFFFFG, ABAEFGCCDFEFFFFFG
Not Slops:   AHDFGA, DFGAH, ABABCC

 

 

 


Write a program that will read input from a file and determine whether or not a string of characters is a slop. The file will be organized as follows. The first line contains an integer N between 1 and 100 indicating how many strings of characters are to be tested. The next N lines each contain a string.

Write three recursive methods that determine whether or not a string is a slop. Here are the function signatures:

bool isSlop(string str);

bool isSlap(string str);

bool isSlip(string str);

You will want to write isSlip first, followed by isSlap, and finally isSlop. Make sure that isSlip and isSlap work flawlessly. Do not proceed to isSlop until you are sure that the other two methods work.

Your program should write its output to the console.  The first line of output should read SLOPS OUTPUT.  Each of the next N lines of output should consist of either YES or NO depending on whether or not the corresponding input line is a Slop. The last line of output should read: END OF OUTPUT.

Shown below is a sample run.  The following input data:

2
AHDFG
DFGAH

Should produce the following output:


SLOPS OUTPUT
YES
NO
END OF OUTPUT

Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 4 steps with 1 images

Blurred answer
Knowledge Booster
Problems on Dynamic Programming
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education