Problem Statement
One day, Jamie noticed that many English words only use the letters A and B. Examples of such words include "AB" (short for abdominal), "BAA" (the noise a sheep makes), "AA" (a type of lava), and "ABBA" (a Swedish pop sensation).
Inspired by this observation, Jamie created a simple game.
You are given two
- Add the letter A to the end of the string.
- Add the letter B to the end of the string and then reverse the entire string. (After the reversal the newly-added B becomes the first character of the string).
Return "Possible" (quotes for clarity) if there is a sequence of valid moves that will change initial into target. Otherwise, return "Impossible".
Definition
- Class:
- ABBADiv1
- Method:
- canObtain
- Parameters:
- String, String
- Returns:
- String
- Method signature:
- String canObtain(String initial, String target)
- (be sure your method is public)
Constraints
- The length of initial will be between 1 and 49, inclusive.
- The length of target will be between 2 and 50, inclusive.
- target will be longer than initial.
- Each character in initial and each character in target will be either 'A' or 'B'.
Examples
"A"
"BABA"
Returns: "Possible"
Jamie can perform the following moves: Initially, the string is "A". Jamie adds a 'B' to the end of the string and then reverses the string. Now the string is "BA". Jamie adds a 'B' to the end of the string and then reverses the string. Now the string is "BAB". Jamie adds an 'A' to the end of the string. Now the string is "BABA". Since there is a sequence of moves which starts with "A" and creates the string "BABA", the answer is "Possible".
"BAAAAABAA"
"BAABAAAAAB"
Returns: "Possible"
Jamie can add a 'B' to the end of the string and then reverse the string.
"A"
"ABBA"
Returns: "Impossible"
"AAABBAABB"
"BAABAAABAABAABBBAAAAAABBAABBBBBBBABB"
Returns: "Possible"
"AAABAAABB"
"BAABAAABAABAABBBAAAAAABBAABBBBBBBABB"
Returns: "Impossible"
"BABABBABBBBBBABA"
"BBBBBBABABBABBBABABBBBBBABBABABBBBBBBABAABBBAAAAAB"
Returns: "Possible"
"BAAABBABBBBBBABA"
"BBBBBBABABBABBBABABBBBBBABBABABBBBBBBABAABBBAAAAAB"
Returns: "Impossible"
"BAAAAABBBBABBABBBAABABAAABAABABABAABAB"
"BABBBAABABAABABABAABAAABABAABBBABBABBBBAAAAABBBBAA"
Returns: "Possible"
"BAAAAABBBBABBABBBAABBBAAABAABABABAABAB"
"BABBBAABABAABABABAABAAABABAABBBABBABBBBAAAAABBBBAA"
Returns: "Impossible"
"BBBABAABAAABAAAAAABBAABAAAAABBABBBBBA"
"BABBAABBBABAABAAABAAAAAABBAABAAAAABBABBBBBABBAABAA"
Returns: "Possible"
"BBBABAABAAABAAAAAABBAABAAAAABBABBBBBB"
"BABBAABBBABAABAAABAAAAAABBAABAAAAABBABBBBBABBAABAA"
Returns: "Impossible"
"ABABABBABABBAABAABBAABAAAAAB"
"BAAAAAAAABAABABAAAAABAABBAABAABBABABBABABABAABAAAA"
Returns: "Possible"
"BBABABBABABBAABAABBAABAAAAAB"
"BAAAAAAAABAABABAAAAABAABBAABAABBABABBABABABAABAAAA"
Returns: "Impossible"
"BBBAABAABABBABAABBABABBABAABABBABBAABAAABBBBBBB"
"BBBBAABAABABBABAABBABABBABAABABBABBAABAAABBBBBBBAB"
Returns: "Possible"
"BBBAABAABABBABAABBABABBABAABABBABBABBAAABBBBBBB"
"BBBBAABAABABBABAABBABABBABAABABBABBAABAAABBBBBBBAB"
Returns: "Impossible"
"BAAB"
"BABAAAABBAABAAAABAAABAB"
Returns: "Possible"
"BABB"
"BABAAAABBAABAAAABAAABAB"
Returns: "Impossible"
"A"
"BBAAABBBBAABABABBAAABABAABAAAABABBAABBBAAABB"
Returns: "Possible"
"B"
"BBAAABBBBAABABABBAAABABAABAAAABABBAABBBAAABB"
Returns: "Possible"
"BBBBAABB"
"BBBBBAABBAAAAABAA"
Returns: "Possible"
"BABBAABB"
"BBBBBAABBAAAAABAA"
Returns: "Impossible"
"AB"
"BABBAAABAABBBABBBBAAABBBAABA"
Returns: "Possible"
"AA"
"BABBAAABAABBBABBBBAAABBBAABA"
Returns: "Impossible"
"ABA"
"BABBBBAABBBAABABAABABBBBAB"
Returns: "Possible"
"BBA"
"BABBBBAABBBAABABAABABBBBAB"
Returns: "Impossible"
"A"
"BBBABABBAABAAABBBBBAABAABAABBABABBBBBABBBBABAAAABA"
Returns: "Possible"
"B"
"BBBABABBAABAAABBBBBAABAABAABBABABBBBBABBBBABAAAABA"
Returns: "Possible"
"BBAABBABBABABBAAABAABABBAABABABBABBBBAABAABBABBBB"
"BBBBBABBAABAABBBBABBABABAABBABAABAAABBABABBABBAABB"
Returns: "Possible"
"ABAABBABBABABBAAABAABABBAABABABBABBBBAABAABBABBBB"
"BBBBBABBAABAABBBBABBABABAABBABAABAAABBABABBABBAABB"
Returns: "Impossible"
"AAAAA"
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
Returns: "Possible"
"BBBBB"
"BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB"
Returns: "Possible"
"AAAAA"
"BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB"
Returns: "Impossible"
"BBBBB"
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
Returns: "Impossible"
"BBBAA"
"BAABAAABBBBAAAAAABAAABABBAAABAAABAABBBBAABAABBAABA"
Returns: "Impossible"
"BABABAAAAB"
"AABABAAAAAAABBBBBAABAAAABBABBAABBAABABABABBABAAABB"
Returns: "Impossible"
"ABBAAAABABBABAAAAABB"
"BABBAAAABBAABBBAAABBBBBBAABBAABABAAABBAABBABBBBBAB"
Returns: "Impossible"
"ABBBBBBBBBBBABABBA"
"BABBBBBBBBBBBABABBA"
Returns: "Impossible"
"ABBBBBBBBBBBABABBA"
"BABBABABBBBBBBBBBBA"
Returns: "Possible"
"AAABAAAAABAABBBAAABABABBBBABBBABABBAAABBBBBABA"
"AABABBBBBAAABBABABBBABBBBABABAAABBBAABAAAAABAAAB"
Returns: "Impossible"
"AAABAAAAABAABBBAAABABABBBBABBBABABBAAABBBBBABA"
"BABABBBBBAAABBABABBBABBBBABABAAABBBAABAAAAABAAAA"
Returns: "Possible"
"AAAAAAAAAAAAAAAAAAAAAAAAAB"
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB"
Returns: "Impossible"
"BB"
"BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBA"
Returns: "Possible"
"BB"
"ABBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB"
Returns: "Impossible"
"BABBBAAAB"
"BAAAAABABABABABAABABBBAAABBABBBAAABB"
Returns: "Possible"
"BABABAAAB"
"BAAAAABABABABABAABABBBAAABBABBBAAABB"
Returns: "Impossible"
"B"
"AB"
Returns: "Impossible"
"BAABBBBAAB"
"BAABBABBBBBBAAAABABAABBBBAABBBBABAAABABBAAAABBAAAA"
Returns: "Possible"
"BBB"
"ABBB"
Returns: "Impossible"
"BA"
"BABABBAAAAAAAAAABBBAAAABBAAABBABBBBBABAABBAABBAB"
Returns: "Possible"
"BBAA"
"ABBAA"
Returns: "Impossible"
"BAB"
"AAABAB"
Returns: "Impossible"
"A"
"ABAB"
Returns: "Impossible"
"AA"
"ABAAB"
Returns: "Impossible"
"BBB"
"ABBBBBA"
Returns: "Impossible"
"A"
"BABABABABABABABABABABABABABABABABABABABABABABABABA"
Returns: "Possible"
"AA"
"ABAA"
Returns: "Impossible"
"AAAA"
"AAAAAAA"
Returns: "Possible"
"BBA"
"ABABBBAABBABBAAAAABABAABBBBABBABBBBBBBBBBABBABABAA"
Returns: "Impossible"
"AB"
"ABBB"
Returns: "Impossible"
"A"
"AA"
Returns: "Possible"
"BB"
"ABBA"
Returns: "Impossible"
"AAB"
"ABAABAB"
Returns: "Impossible"
"BA"
"ABAA"
Returns: "Impossible"
"AA"
"ABAABA"
Returns: "Impossible"
"A"
"ABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
Returns: "Impossible"
"A"
"AB"
Returns: "Impossible"
"AB"
"BAB"
Returns: "Impossible"
"ABB"
"AABBA"
Returns: "Impossible"
"ABBA"
"BABBAABA"
Returns: "Possible"
"ABAB"
"BABAB"
Returns: "Impossible"
"BA"
"BAAB"
Returns: "Possible"
"A"
"BAAAAAAA"
Returns: "Possible"
"B"
"ABA"
Returns: "Impossible"
"BAB"
"ABABABA"
Returns: "Impossible"
"BBB"
"BBBBB"
Returns: "Possible"
"BAB"
"ABABA"
Returns: "Impossible"
"BAAB"
"BAAAABAABA"
Returns: "Possible"
"AB"
"ABB"
Returns: "Impossible"
"AAAAAAB"
"AAAAAABA"
Returns: "Possible"
"ABA"
"AABA"
Returns: "Impossible"
"AB"
"AABA"
Returns: "Impossible"
"BB"
"AABBAA"
Returns: "Impossible"
"AAA"
"AAABAAABAAA"
Returns: "Impossible"
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
"BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
Returns: "Possible"
"BA"
"BABB"
Returns: "Impossible"
"BBAB"
"ABBABA"
Returns: "Impossible"
"B"
"BBA"
Returns: "Possible"
"B"
"BBBB"
Returns: "Possible"
"A"
"ABABA"
Returns: "Impossible"
"AABA"
"AABAAA"
Returns: "Possible"
"BB"
"BBBABAB"
Returns: "Impossible"