Problem Statement
Given a
Strings are case sensitive, and only upper case letters and lower case letters are allowed in input.
For example, in the string "ABCDEXXXYYYZZZABCDEZZZYYYXXX" the longest substring which appears at least twice is "ABCDE". These two substrings do not overlap so you would return 5.
Definition
- Class:
- Reppity
- Method:
- longestRep
- Parameters:
- String
- Returns:
- int
- Method signature:
- int longestRep(String input)
- (be sure your method is public)
Notes
- We are looking for subSTRINGS not subSEQUENCES. All of the elements of a substring appear consecutively in the original string. In other words, the substring can be formed from the original string by deleting zero or more characters from the begining and deleting zero or more characters from the end, but NO deletions from the middle are allowed.
Constraints
- input will contain between 1 and 50 characters inclusive.
- Each character in input will be between 'a' and 'z' inclusive or between 'A' and 'Z' inclusive.
Examples
"ABCDEXXXYYYZZZABCDEZZZYYYXXX"
Returns: 5
The example from above.
"abcdabcdabcdabCD"
Returns: 6
"abcdab"+"cd"+"abcdab"+"CD"
"abcdefghijklmnopqrstuvwxyabcdefghijklmnopqrstuvwxy"
Returns: 25
"againANDagainANDagainANDagainANDagainANDagain"
Returns: 21
"abcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabc"
Returns: 24
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWX"
Returns: 0
"x"
Returns: 0
"sdsdsdsdsdsdsdsdsdsdsdsdsd"
Returns: 12
"ohbabybabybabyboy"
Returns: 5
"thisexampleisbrokennoitisntohwait"
Returns: 2
"dobedobedobedobedobe"
Returns: 8
"tobeornottobeisnottobethequestion"
Returns: 7
"aa"
Returns: 1
"ab"
Returns: 0
"iiuiuioiiuiuuuiooopiooiuoiuoioiuiuiuo"
Returns: 5
"djkdkkfkfkdkskskkdkdfkkfkdkdkdjdkdkkkfjjkdfks"
Returns: 5
"kkdkkdkdkdkdkdkdkdkdkdkdkdkdkdkdkdkdkddkkd"
Returns: 16
"aaaaabbbbbaaaaabbbbbaaaaabbbbbaaaaabbbbbaaaaabbbbb"
Returns: 20
"aaaaaaaaaabbbbbbbbbbaaaaaaaaaabbbbbbbbbbaaaaaaaaaa"
Returns: 20
"aabbaaabbbaaaabbbbaaaaabbbbbaaaaaabbbbbbaaaaabbbbb"
Returns: 14
"foglogfrogdoghogtogslogcogboggoggoogle"
Returns: 3
"catdogdogcatcatcatdogcatcatdog"
Returns: 9
"RustyoldmanrustyoldmanRustydustyoldman"
Returns: 10
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
Returns: 24
"xxx"
Returns: 1
"zzzz"
Returns: 2
"cokedietcokedietcokedietcoke"
Returns: 12
"aaaboobaaoooboobaaeee"
Returns: 6
"abcdefghijklmnopqrstuvwxyza"
Returns: 1
"abcedefhijjklmnopqrstuvwxyz"
Returns: 1
"Rustyoldmanisthegreatestwriter"
Returns: 2
"ababdeaffdaaffd"
Returns: 4
"aa"
Returns: 1
"againANDagainANDagainANDagainANDagainANDagain"
Returns: 21
"abab"
Returns: 2
"ABCDEFGHIJKLMNOPabcdabcda"
Returns: 4
"abcAbc"
Returns: 2
"abcdefghzxbzx"
Returns: 2
"abcdefgxyzxyz"
Returns: 3
"abcdefghdkdk"
Returns: 2
"XYZYZX"
Returns: 2
"abcdabcdABCDEFGHI"
Returns: 4
"qwertyuiopaa"
Returns: 1
"ABCNBCN"
Returns: 3
"qwertyuzz"
Returns: 1
"AA"
Returns: 1