Problem Statement
For example, "abcabcdabcabcdxyxyz" could be expressed in compressed form as "abcRdRMxyRz". To decompress this, the beginning abc is first repeated to become "abcabc", then "d" is added, and then all of that is repeated to make "abcabcdabcabcd". This is followed by the "xy" which is repeated and followed by the "z".
Create a class Repeat that contains a method minLength that is given the text to be compressed and that returns the minimum number of characters that can be used to express it with this compression technique. Of course all the 'R' and 'M' characters must be counted.
Definition
- Class:
- Repeat
- Method:
- minLength
- Parameters:
- String
- Returns:
- int
- Method signature:
- int minLength(String text)
- (be sure your method is public)
Constraints
- text will contain between 1 and 50 characters, inclusive.
- Each character in text will be a lowercase letter 'a'-'z'.
Examples
"aaaaaaaa"
Returns: 4
Either "aRRR" or "aaRR" is a way of compressing this to 4 characters.
"aaaaaaa"
Returns: 5
One way is with "aaaRa"
"bcdcdcdcdxcdcdcdcd"
Returns: 12
One way is "bMcdRRxMcdRR"
"xyz"
Returns: 3
You can always use no 'R's or 'M's.
"abxababababababab"
Returns: 12
"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
Returns: 8
"zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz"
Returns: 9
"aabbccddeeffgghhiijjkkllmmnnooppqqrrssttuuvvwwxxyy"
Returns: 50
"ttttttttttttttttttttttttttttttttttttttttttttttt"
Returns: 10
"ababaabbaaabbbababaabbaabbaabbbaabbbabab"
Returns: 34
"abcabcdabcabcdxyxyz"
Returns: 11
From the description.
"ababcabcdabcdeabcdefabcdefgabcdefgh"
Returns: 26
"baaaaaabaaaaaaa"
Returns: 9
"bbabaababbabaaba"
Returns: 9
"baaaaaabaabaaabaabb"
Returns: 14
"aabbbbbbbaaabbbbbbba"
Returns: 11
"abaaaaaaabbbbabbaababbabbbba"
Returns: 25
"bbababcabbbcbcccbababbabacacccbba"
Returns: 32
"abecaebbaeccaaebdbdcadabdabbaaab"
Returns: 31
"bdafdefadbbfacedefeeddfacfddeafad"
Returns: 33
"b"
Returns: 1
"deaffabfbafbaec"
Returns: 14
"aaaaaaa"
Returns: 5
"acbcabccabbbcbbcbbbcbabbcbcacaacabcbabbacacbaac"
Returns: 44
"babababaababbaaaabba"
Returns: 16
"baabbaabbaabbaa"
Returns: 12
"badabaddcbdcbdbcdcadbdabdacbc"
Returns: 27
"edafakcd"
Returns: 8
"fabjbggihcegbaeeijhbhhbkdfhbcfbgkfij"
Returns: 36
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
Returns: 9
"ccccacbbadbaaeaeabadaebdbbdcedadaacbecaaeceb"
Returns: 43
"gbvvsmvrmjqpkdow"
Returns: 16
"dccbaadh"
Returns: 8
"ffhblbidbjcidfljcaieejecba"
Returns: 26
"clbiidchckclfkllghlajhed"
Returns: 24
"lopdglrpmtifrmsoqooigjnkpmdqdtpthkqnlrfcgqbobiqd"
Returns: 48
"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxmxxxxxxxxxxxxxxxxxx"
Returns: 17
"abaaabaa"
Returns: 5
"babbabbabbabb"
Returns: 6
"qqqq"
Returns: 3
"abcdefghijklmnopqrstuvwxyz"
Returns: 26
"bcdcdcdcdxcdcdcdcd"
Returns: 12
"bcdcdcdcdcdcdcdcdbcdcdcdcdcdcdcdcd"
Returns: 14
"aaaabaaaabaaaabaaaabaaaabaaaabaaaabaaaac"
Returns: 21
"mxcdcdcdcdxcdcdcdcdbxcdcdcdcdxcdcdcdcdb"
Returns: 14
"dqefgqefghijmhijmqefgqefghijmhijmopopopopopopo"
Returns: 24
"abbbbbbbbabbbbbbbb"
Returns: 10
"aabcabcaabcabc"
Returns: 8
"aaaaaaaaccccccccaaaaaaaacccccccc"
Returns: 13
"accccccbaccccccb"
Returns: 9
"aabcdcdcdcdxcdcdcdcdabcdcdcdcdxcdcdcdcd"
Returns: 22
"kabcdabcdkkabcdabcdk"
Returns: 11
"asdvasdfasdasdfasdfasdasdffsdafasdfasdasdffasdfaas"
Returns: 39
"ababbababbbababbababb"
Returns: 12
"ababababababababababababababababababababababababab"
Returns: 10
"aaababababababaababbaabaabbbbbbbbbaaaaaaxaaaaaa"
Returns: 36
"aaaaaaaaaabbbbbbbbbbaaaaaaaaaabbbbbbbbbb"
Returns: 16
"abcabcabcabcabcabc"
Returns: 8
"bcdcdcdcdbcdcdcdcd"
Returns: 10
"xmnabcabcmnabcabc"
Returns: 11
"aaaaaaaaaaaabbbbbbbbbbbbaaaaaaaaaaaabbbbbbbbbbbb"
Returns: 18
"cababababcabababab"
Returns: 10