Problem Statement
There are some books, each consisting of exactly three parts: introduction, story and edification. There is a reader who goes through the books and reads various parts. Each time he finishes reading a part, he adds the name of the part to the end of a list. He may read zero or more parts from each book, and he can read them in any order, but he cannot read each part more than once. Whenever he starts reading a new book, he can no longer go back and read any parts of books he has looked at previously.
You are given a
Definition
- Class:
- ReadingBooks
- Method:
- countBooks
- Parameters:
- String[]
- Returns:
- int
- Method signature:
- int countBooks(String[] readParts)
- (be sure your method is public)
Constraints
- readParts will contain between 1 and 50 elements, inclusive.
- Each element of readParts will be "introduction", "story" or "edification" (quotes for clarity).
Examples
{"edification", "story", "introduction", "edification", "introduction", "story", "edification"}
Returns: 2
{"introduction", "story", "introduction", "edification"}
Returns: 1
It is possible that the reader has read the introduction from the first book and all 3 parts from the second one. Of course, it is also possible that he has read one part from four different books, but we are interested in the maximal number of books for which all 3 parts have been read.
{"story", "edification", "introduction", "story", "edification", "introduction", "introduction", "story", "edification", "introduction"}
Returns: 3
{"introduction", "introduction", "introduction", "story", "story", "story", "edification", "edification", "edification"}
Returns: 0
{"introduction", "story", "edification", "introduction", "story", "edification"}
Returns: 2
Two books have been read in their entirety.
{"introduction", "story", "edification", "introduction"}
Returns: 1
{"introduction", "story", "edification", "introduction", "story", "edification", "introduction", "story", "edification", "introduction", "story", "edification", "introduction", "story", "edification", "introduction", "story", "edification"}
Returns: 6
{"story", "story", "introduction", "edification", "story", "introduction", "introduction", "edification", "edification", "edification", "story", "story", "introduction", "introduction", "edification", "edification", "story", "introduction", "edification", "story", "edification", "edification", "edification", "introduction", "introduction", "introduction", "edification", "story"}
Returns: 3
{"introduction", "introduction", "edification", "edification", "story", "introduction", "introduction", "edification", "edification", "story", "introduction", "edification", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "introduction", "introduction", "edification", "story", "story", "introduction", "introduction"}
Returns: 6
{"story", "story", "story", "introduction", "introduction", "introduction", "edification", "story", "edification", "introduction", "story", "story", "introduction", "edification", "edification", "introduction", "edification", "introduction", "edification", "story", "story", "introduction", "edification", "introduction", "story", "edification", "introduction", "story", "story", "introduction", "edification"}
Returns: 7
{"edification", "edification", "introduction", "introduction", "story", "edification", "introduction", "introduction", "story", "introduction", "edification", "edification", "story", "edification", "introduction", "introduction", "edification", "edification", "story", "introduction", "edification", "introduction", "story", "introduction", "story", "introduction", "edification", "story", "introduction", "edification", "story", "edification", "introduction", "story"}
Returns: 8
{"edification", "edification", "introduction", "introduction", "story", "introduction", "edification", "edification", "introduction", "story", "introduction", "introduction", "story", "story", "edification", "introduction", "story", "edification", "introduction", "story", "edification", "edification", "introduction", "story", "introduction", "edification", "edification", "introduction", "story"}
Returns: 6
{"story", "edification", "introduction", "edification", "edification", "edification", "story", "edification", "story", "edification", "edification", "story", "introduction", "story", "introduction"}
Returns: 2
{"introduction", "story", "story", "edification", "introduction", "story", "introduction", "story", "introduction", "story", "introduction", "introduction", "edification", "edification", "story", "introduction", "story", "introduction", "story", "introduction", "edification", "introduction", "edification", "story", "story", "introduction", "edification", "introduction", "edification", "introduction", "story", "introduction", "edification", "edification", "story", "story", "introduction", "story", "edification", "story", "story", "edification", "story"}
Returns: 7
{"edification", "introduction", "edification", "story", "edification", "edification", "story", "edification", "introduction", "edification", "story"}
Returns: 2
{"story", "edification", "introduction", "introduction", "introduction", "edification", "edification", "story", "story", "introduction", "edification", "introduction", "edification", "story", "introduction", "story", "introduction", "introduction", "story", "story", "edification", "story", "edification", "edification", "introduction", "story", "introduction", "story", "edification"}
Returns: 5
{"introduction", "edification", "introduction", "story", "introduction", "edification", "edification", "story", "introduction", "story", "introduction", "edification", "edification", "introduction", "edification", "edification"}
Returns: 3
{"introduction", "introduction", "introduction", "edification", "story", "edification", "introduction", "introduction", "introduction", "edification", "introduction", "edification", "edification", "introduction", "story", "introduction", "story", "introduction", "introduction", "story", "introduction", "story", "edification", "introduction", "story", "edification", "story", "edification", "story", "edification", "introduction", "introduction", "story", "story", "introduction"}
Returns: 5
{"introduction", "story", "introduction", "edification", "story", "introduction"}
Returns: 1
{"edification", "story", "introduction", "introduction", "introduction", "story", "introduction", "story", "story", "story", "story", "introduction", "story", "introduction", "introduction", "story", "edification", "story", "edification", "story", "introduction", "introduction", "story", "story", "introduction", "introduction", "story", "introduction", "story", "introduction", "introduction", "introduction", "introduction", "story", "edification", "introduction", "story", "story", "introduction", "introduction", "edification", "edification", "introduction", "introduction", "story", "edification", "edification", "edification", "introduction", "edification"}
Returns: 5
{"introduction", "story", "introduction", "story", "introduction", "edification", "story", "introduction", "story", "story", "edification", "story", "story", "introduction", "introduction", "introduction", "introduction", "edification", "story", "story", "story", "story", "story", "story", "story", "edification", "story", "story", "introduction", "edification", "story", "story", "edification", "edification", "edification", "introduction", "edification", "edification", "story", "story", "edification", "story", "edification", "edification"}
Returns: 3
{"edification", "story", "introduction", "story", "edification", "story", "story", "story", "edification", "edification", "edification", "edification", "edification", "edification", "edification", "introduction", "story", "edification", "edification", "edification", "story", "introduction", "story", "story", "story", "introduction", "introduction", "introduction"}
Returns: 3
{"introduction", "introduction", "story", "introduction", "introduction", "introduction", "introduction", "story", "introduction", "story", "story", "edification", "edification", "story", "edification", "story", "edification", "introduction", "edification", "edification", "story", "edification", "introduction", "edification", "edification", "introduction", "introduction", "edification", "introduction", "introduction", "edification", "introduction", "edification", "introduction", "story", "introduction", "story", "introduction", "story", "story", "introduction", "story", "story", "edification", "edification", "edification", "edification", "introduction", "introduction", "introduction"}
Returns: 3
{"introduction", "edification", "edification", "introduction", "introduction", "edification", "edification", "edification", "introduction", "introduction", "edification", "story", "edification", "edification", "story", "edification", "story", "story", "story", "story", "introduction", "edification", "introduction", "edification", "introduction", "edification", "edification", "edification", "introduction", "introduction", "edification", "story", "story", "story", "story", "introduction", "introduction", "edification", "story", "story", "edification", "story", "edification", "introduction", "edification", "story", "story", "introduction", "edification", "story"}
Returns: 6
{"introduction", "story", "introduction", "edification", "introduction", "story", "introduction", "story", "introduction", "introduction", "edification", "story", "introduction", "introduction", "introduction", "story", "story", "introduction", "introduction", "introduction", "story", "edification", "introduction", "edification", "story", "edification", "introduction", "story", "introduction", "edification", "edification", "edification", "introduction", "story", "edification", "edification", "introduction", "introduction", "introduction", "story", "story", "story", "edification", "edification", "story", "story", "story", "story", "introduction", "introduction"}
Returns: 6
{"story", "story", "introduction", "story", "story", "introduction", "edification", "edification", "story", "introduction", "story", "story", "story", "introduction", "story", "introduction", "edification", "introduction", "introduction", "edification", "introduction", "introduction", "introduction", "story", "story", "introduction", "edification", "story", "edification", "story", "story", "introduction", "introduction", "edification", "story", "introduction", "introduction", "edification", "edification", "story", "introduction", "introduction", "story", "edification", "story", "edification", "edification", "story", "edification", "edification"}
Returns: 7
{"introduction", "introduction", "introduction", "story", "introduction", "edification", "edification", "story", "introduction", "introduction", "edification", "story", "edification", "introduction", "story", "story", "edification", "edification", "story", "edification", "story", "story", "introduction", "edification", "introduction", "story", "edification", "introduction", "introduction", "introduction", "story", "story", "story", "story", "edification", "introduction", "story", "introduction", "edification", "edification", "story", "edification", "edification", "story", "story", "introduction", "edification", "introduction", "introduction", "introduction"}
Returns: 9
{"story", "story", "edification", "story", "story", "edification", "edification", "edification", "story", "introduction", "introduction", "edification", "story", "edification", "story", "edification", "story", "introduction", "story", "introduction", "introduction", "story", "introduction", "story", "story", "edification", "edification", "story", "edification", "story", "introduction", "edification", "introduction", "story", "introduction", "edification", "story", "edification", "story", "edification", "edification", "edification", "introduction", "introduction", "edification", "story", "introduction"}
Returns: 7
{"story", "edification", "edification", "story", "story", "introduction", "edification", "introduction", "edification", "story", "story", "edification", "introduction", "introduction", "edification", "edification", "story", "edification", "introduction", "introduction", "story", "edification", "introduction", "story", "edification", "story", "story", "story", "story", "introduction", "introduction", "story", "introduction", "edification", "story", "edification", "introduction", "story", "introduction", "story", "edification", "story", "edification"}
Returns: 9
{"introduction", "story", "story", "introduction", "edification", "story", "introduction", "story"}
Returns: 1
{"story", "story", "edification", "introduction", "edification", "introduction", "story", "introduction", "story", "edification", "introduction", "introduction", "introduction", "story", "edification", "introduction", "introduction", "edification", "introduction", "edification", "introduction", "introduction", "introduction", "story", "edification", "edification", "edification", "story", "edification", "introduction", "story", "introduction", "story", "introduction", "edification", "story", "story", "story", "story", "introduction", "story", "edification", "edification", "edification"}
Returns: 8
{"story", "introduction", "introduction", "story", "edification", "story", "edification", "edification", "edification", "story", "edification", "introduction", "story", "edification", "edification", "edification", "introduction", "introduction", "story", "introduction", "edification", "story", "introduction", "story", "introduction", "story", "edification", "story", "introduction", "introduction", "introduction", "story", "introduction", "edification", "edification", "story", "edification", "edification", "story", "story", "edification", "edification", "edification", "edification", "introduction", "story", "story", "introduction", "introduction"}
Returns: 6
{"edification", "edification", "story", "story", "story", "story", "edification", "edification", "introduction", "edification", "edification", "introduction", "introduction"}
Returns: 0
{"story", "edification", "edification", "story", "introduction", "introduction", "introduction", "edification", "story", "edification", "story", "introduction", "introduction", "introduction", "edification", "introduction", "introduction", "edification", "story", "story", "story", "story", "introduction", "story", "edification", "edification", "edification", "introduction", "edification"}
Returns: 5
{"story", "story", "introduction", "story", "story", "story", "story", "edification", "story", "introduction", "story", "introduction", "edification", "story", "introduction", "introduction", "edification", "introduction", "story", "introduction", "edification", "story", "edification"}
Returns: 4
{"introduction", "story", "introduction", "story", "story", "story", "edification", "introduction", "edification", "edification", "introduction", "story", "edification", "introduction", "edification", "story", "edification", "story", "story", "introduction", "introduction", "introduction", "story", "story", "introduction", "introduction", "introduction", "edification", "edification", "introduction", "story", "edification", "story", "story", "introduction", "edification", "edification", "introduction", "story", "introduction"}
Returns: 6
{"introduction", "edification", "edification", "story", "introduction", "introduction", "edification", "story", "edification", "edification", "introduction", "story", "story", "introduction", "introduction", "story", "story", "story", "story", "story", "edification", "story"}
Returns: 3
{"edification", "story", "introduction", "story", "edification", "introduction", "story", "introduction", "edification", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story", "introduction", "edification", "story"}
Returns: 16
{"introduction", "story", "introduction", "edification", "story", "story", "edification", "edification", "edification", "introduction", "introduction", "edification", "story", "introduction", "story", "edification", "edification", "story", "introduction", "edification", "story", "story", "edification", "introduction", "story"}
Returns: 5
{"story"}
Returns: 0
{"introduction"}
Returns: 0
{"edification"}
Returns: 0
{"story","edification"}
Returns: 0
{"introduction","edification"}
Returns: 0
{"edification","edification"}
Returns: 0
{"introduction","introduction","introduction"}
Returns: 0
{"introduction","edification","edification"}
Returns: 0
{"story","edification","introduction"}
Returns: 1
{"introduction", "story", "story", "story", "edification", "introduction", "story", "story", "story", "edification", "edification", "introduction", "edification", "edification", "introduction", "introduction", "story", "edification", "introduction", "story", "introduction", "story", "story", "edification", "edification", "story", "edification", "introduction", "introduction", "edification", "edification", "introduction", "story", "introduction", "story", "edification", "story", "edification", "introduction", "edification", "story", "edification", "edification", "story", "introduction" }
Returns: 7
{"introduction", "story", "introduction", "edification", "story", "story", "edification", "edification", "edification", "introduction", "introduction", "edification", "story", "introduction", "story", "edification", "edification", "story", "introduction", "edification", "story", "story", "edification", "introduction", "story" }
Returns: 5
{"introduction" }
Returns: 0
{"story", "edification", "introduction" }
Returns: 1
{"story", "story", "story" }
Returns: 0
{"story", "introduction", "edification" }
Returns: 1
{"story", "story", "story", "edification", "edification", "edification", "introduction", "introduction", "introduction" }
Returns: 0
{"edification", "story", "introduction" }
Returns: 1
{"introduction", "story", "introduction", "edification", "story", "introduction" }
Returns: 1
{"introduction", "introduction", "story", "story", "edification", "edification" }
Returns: 0
{"story", "introduction", "introduction", "edification" }
Returns: 0
{"introduction", "story", "introduction", "edification" }
Returns: 1
{"story", "edification", "introduction", "story" }
Returns: 1
{"introduction", "story", "introduction", "edification", "story", "story", "edification", "edification", "edification", "introduction", "introduction", "edification", "story", "introduction", "story", "edification", "edification", "story", "introduction", "edification", "story", "story", "edification", "introduction", "story", "story", "introduction", "story", "story", "story", "edification", "introduction", "story", "story", "introduction", "introduction", "edification" }
Returns: 6
{"introduction", "story", "introduction", "edification", "story", "story", "edification", "edification", "edification", "introduction", "introduction", "edification", "story", "introduction", "story", "edification", "edification", "story", "introduction", "edification", "story", "story", "edification", "introduction", "story", "introduction", "introduction", "introduction", "introduction", "story", "story", "story", "edification", "edification", "edification", "edification" }
Returns: 5
{"introduction", "story", "edification", "edification" }
Returns: 1
{"story", "story", "story", "story" }
Returns: 0
{"introduction", "story", "edification", "edification", "story", "introduction" }
Returns: 2
{"story", "introduction", "introduction", "edification", "introduction", "introduction", "story", "story", "story", "edification", "story", "introduction", "introduction", "edification", "story", "edification", "introduction", "introduction", "story", "story", "introduction", "story", "story", "edification", "story", "edification", "introduction", "story", "edification", "edification", "story", "introduction", "edification" }
Returns: 4
{"introduction", "introduction", "edification", "edification", "story", "story" }
Returns: 0
{"introduction", "story", "introduction", "edification", "story", "story", "edification", "edification", "edification", "introduction", "introduction", "edification", "story", "introduction", "story", "edification", "edification", "story", "introduction", "edification", "story", "story", "edification", "introduction", "story", "story", "edification", "introduction", "edification", "edification", "edification", "edification", "introduction", "introduction", "introduction", "story", "story", "story", "story", "story", "introduction", "edification", "story", "edification", "introduction", "introduction", "introduction" }
Returns: 8
{"introduction", "introduction", "introduction", "introduction", "introduction", "introduction", "story", "story", "edification", "edification" }
Returns: 0
{"introduction", "introduction", "introduction", "story", "story", "story", "edification", "edification", "edification" }
Returns: 0
{"introduction", "edification" }
Returns: 0
{"introduction", "story", "story", "edification", "edification" }
Returns: 0
{"story", "introduction", "introduction", "edification", "introduction", "introduction", "story", "story", "story", "edification", "story", "introduction", "introduction", "edification", "story", "edification", "introduction", "introduction", "story", "story", "introduction", "story", "story", "edification", "story", "edification", "introduction", "story", "edification", "edification", "story", "introduction", "edification", "introduction", "story", "edification", "story" }
Returns: 5
{"introduction", "introduction", "story", "story", "edification" }
Returns: 0
{"story" }
Returns: 0
{"introduction", "story", "introduction", "edification", "introduction", "story", "introduction", "edification", "introduction", "story", "introduction", "edification", "introduction" }
Returns: 3
{"introduction", "introduction", "story", "introduction", "edification" }
Returns: 1
{"introduction", "edification", "introduction", "edification", "story", "introduction", "story", "edification", "introduction", "edification", "edification", "story", "story", "story", "story", "introduction", "story", "story", "introduction", "edification", "edification", "introduction", "edification", "edification", "edification", "story", "introduction", "edification", "edification", "edification", "edification", "edification", "edification", "story", "story", "edification", "story", "introduction", "edification", "edification", "edification", "story", "introduction", "edification", "story", "edification", "story", "introduction", "story", "story" }
Returns: 7
{"introduction", "story", "edification", "introduction", "story", "edification" }
Returns: 2
{"introduction", "story", "story", "edification" }
Returns: 0
{"introduction", "story", "edification", "edification", "edification", "introduction", "story" }
Returns: 2
{"introduction", "story", "edification", "story" }
Returns: 1
{"story", "story" }
Returns: 0
{"edification", "introduction", "story", "introduction" }
Returns: 1
{"introduction", "story", "edification", "introduction", "edification", "introduction", "edification", "story" }
Returns: 2